home *** CD-ROM | disk | FTP | other *** search
/ HPAVC / HPAVC CD-ROM.iso / INTER52D.ZIP / INTERRUP.O < prev    next >
Text File  |  1996-10-20  |  198KB  |  4,888 lines

  1. Interrupt List, part 15 of 15
  2. Copyright (c) 1989,1990,1991,1992,1993,1994,1995,1996 Ralf Brown
  3. ----------80---------------------------------
  4. INT 80 - Q-PRO4 - ???
  5. --------r-80---------------------------------
  6. INT 80 - reserved for BASIC
  7. Note:    this vector and INT 81 through INT ED are modified but not restored by
  8.       Direct Access v4.0, and may be left dangling by other programs
  9.       written with the same version of compiled BASIC
  10. SeeAlso: INT 81"BASIC",INT 86"BASIC",INT EF"BASIC"
  11. --------E-80---------------------------------
  12. INT 80 - Phar Lap 386|DOS-Extender - RELOCATED PRINT-SCREEN
  13. Note:    the extender relocates INT 05 to here by default, but can be told to
  14.       leave INT 05 alone with the commandline (or DOSX= environment
  15.       variable) flag -PRIVEC 5
  16. SeeAlso: INT 05"PRINT SCREEN"
  17. --------d-80---------------------------------
  18. INT 80 - BusLogic BT-946C PCI SCSI Adapter - SCRATCHPAD RAM (NOT A VECTOR!)
  19. Note:    the factory-default location for the eight bytes of scratchpad RAM
  20.       needed by the SCSI adapter is 0000h:0200h, which is interrupt
  21.       vectors 80h and 81h
  22. SeeAlso: INT 81"BusLogic"
  23. --------b-80---------------------------------
  24. INT 80 U - AMI BIOS v1.00.12.AX1T - internal - BIOS SUBSYSTEM SELECTION
  25.     AH = function
  26.         00h install and initialize BIOS subsystem
  27.         AL = ??? (00h,01h,03h)
  28.         CX:BX = subsystem ID (see #3220)
  29.         ESI = address from which to load, or 00000000h for default for
  30.             subsystem
  31.         EDI = physical address at which to install, or 0 for default
  32.         Note:    if CX=0000h on entry, this call is applied to all
  33.               subsystems whose ID has low word BX
  34.         01h get BIOS subsystem information
  35.         CX:BX = subsystem ID (see #3220)
  36.         Return: AL = ???
  37.             AH = ???
  38.             EDX = uncompressed size of subsystem in bytes
  39.             SI = offset within subsystem of initialization
  40.                 routine, or FFFFh if none
  41.             EDI = physical address of default location or 0
  42.         02h get matching subsystem identifier
  43.         AL = index into subsystem list (return ALth occurrence
  44.               matching BX)
  45.         BX = low word of subsystem identifier
  46.             (0001h,0002h,0004h,0005h,000Bh,FFFFh)
  47.         Return: CF clear if successful
  48.                 CX = high word of ALth matching subsystem
  49.             CF set on error
  50.         Note:    the system is halted if AL=00h on entry
  51.         03h set up "big real" mode (4G segment limits)
  52.         04h turn off "big real" mode (restore 64K segment limits)
  53.         05h remove BIOS subsystem
  54.         CX:BX = subsystem ID to leave out
  55.         Note:    the system is halted if an invalid (not installed)
  56.               subsystem ID is specified
  57.         06h get installed subsystem info
  58.         CX:BX = subsystem ID (see #3220)
  59.         Return:    CF clear
  60.             EDX = length of ???
  61.             EDI = linear address of start of ???
  62.         Note:    the system is halted if an invalid (not installed)
  63.               subsystem ID is specified
  64. Return: CF clear if successful
  65.     CF set on non-fatal error
  66. Note:    this interrupt vector is cleared to 0000h:0000h near the end of the
  67.       BIOS startup sequence
  68.  
  69. (Table 3220)
  70. Values for AMI BIOS subsystem ID:
  71.  00010001h    ROM BIOS @F000-FFFF
  72.  00010002h    setup??? (loaded @6000-68FF)
  73.  00010005h    APM code
  74.  0001000Bh    language-specific error message set (English)
  75.  00020002h    PnP/PCI ACFG code (loaded @F000-F1FF)
  76.  0001FFFFh
  77.  0002FFFFh    recovery code
  78.  00030004h
  79.  0003FFFFh    BIOS decompression code
  80.  0004000Bh
  81.  00060004h
  82.  0100FFFFh    ACFG data
  83.  10000000h    ROM @C000 (64K)
  84.  10000001h    HMA (48K)
  85.  10000002h    RAM @7A00 (24K)
  86.  10000003h    RAM @8000-BFFF
  87.  10000004h
  88.  10000005h    real-mode address space (0-1M)
  89.  1000000Bh    installed language-specific message set???
  90. --------s-80----BL00-------------------------
  91. INT 80 - SBSIM - "STARTSND" - START SOUND ON SPECIFIED DRIVER
  92.     BL = 00h
  93.     BH = driver number (01h = FM, 02h=DDBV, 03h=memvoice, 05h=MIDI)
  94. Return: AX = initialization result (see #3221)
  95. Program: SBSIM is Creative Labs' SoundBlaster Simplified Interface Module,
  96.       which provides access to multiple drivers for the SoundBlaster
  97.       board through a single interface
  98. Range:    INT 80h to INT BFh, selected automatically
  99. Note:    the SBSIM installation check consists of testing for the signature
  100.       "SBSIM" at offset 103h in the interrupt handler's segment.
  101. SeeAlso: INT 80/BL=01h"SBSIM",INT 80/BL=02h"SBSIM",INT 80/BL=03h"SBSIM"
  102. SeeAlso: INT 80/BX=0000h"SBSIM"
  103.  
  104. (Table 3221)
  105. Values for SBSIM error code:
  106.  01h    busy--currently in use
  107.  02h    bad driver specified
  108.  03h    invalid function
  109.  04h    voice process already active
  110.  05h    couldn't start CT-VOICE
  111.  06h    couldn't start CTVDSK
  112.  07h    invalid SBSIM handle
  113.  08h    buffer not initialized yet
  114.  09h    bad filename
  115.  0Ah    bad file handle
  116.  0Bh    driver not started yet
  117.  0Ch    XMS driver not installed
  118.  0Dh    no free SBSIM handles
  119.  0Eh    bad file type
  120.  0Fh    couldn't free XMS block
  121.  10h    invalid source selected
  122.  11h    get pan position failed
  123.  12h    set pan position failed
  124.  13h    set volume failed
  125.  14h    couldn't start fade/pan
  126.  15h    couldn't stop fade/pan
  127.  16h    couldn't pause fade/pan
  128.  17h    not a fade/pan operation
  129.  18h    bad mode for fade/pan
  130.  19h    couldn't start fade/pan
  131.  1Ah    source not fading/panning
  132.  1Bh    FM or MIDI already playing
  133.  1Ch    bad MIDI mapper format
  134. --------s-80----BL01-------------------------
  135. INT 80 - SBSIM - "PLAYSND" - PLAY MUSIC/VOICE ON SELECTED DRIVER
  136.     BL = 01h
  137.     BH = driver number (01h = FM, 02h=DDBV, 03h=memvoice, 05h=MIDI)
  138. Return: AX = result (see #3221)
  139. SeeAlso: INT 80/BL=00h"SBSIM",INT 80/BL=02h"SBSIM",INT 80/BL=04h"SBSIM"
  140. --------s-80----BL02-------------------------
  141. INT 80 - SBSIM - "STOPSND" - STOP MUSIC/VOICE ON SELECTED DRIVER
  142.     BL = 02h
  143.     BH = driver number (01h = FM, 02h=DDBV, 03h=memvoice, 05h=MIDI)
  144. Return: nothing
  145. SeeAlso: INT 80/BL=00h"SBSIM",INT 80/BL=01h"SBSIM",INT 80/BL=03h"SBSIM"
  146. --------s-80----BL03-------------------------
  147. INT 80 - SBSIM - "PAUSESND" - TEMPORARILY PAUSE PLAYBACK ON SELECTED DRIVER
  148.     BL = 03h
  149.     BH = driver number (01h = FM, 02h=DDBV, 03h=memvoice, 05h=MIDI)
  150. Return: nothing
  151. SeeAlso: INT 80/BL=00h"SBSIM",INT 80/BL=02h"SBSIM",INT 80/BL=04h"SBSIM"
  152. SeeAlso: INT 80/BL=05h
  153. --------s-80----BL04-------------------------
  154. INT 80 - SBSIM - "RESUMESND" - RESTART PLAYBACK ON SELECTED DRIVER
  155.     BL = 04h
  156.     BH = driver number (01h = FM, 02h=DDBV, 03h=memvoice, 05h=MIDI)
  157. Return: nothing
  158. SeeAlso: INT 80/BL=00h"SBSIM",INT 80/BL=03h"SBSIM",INT 80/BL=05h"SBSIM"
  159. --------s-80----BL05-------------------------
  160. INT 80 - SBSIM - "GETSNDSTAT" - GET DRIVER'S STATUS
  161.     BL = 05h
  162.     BH = driver number (01h = FM, 02h=DDBV, 03h=memvoice, 05h=MIDI)
  163. Return: AX = status
  164. SeeAlso: INT 80/BL=00h"SBSIM",INT 80/BL=01h"SBSIM",INT 80/BL=03h"SBSIM"
  165. --------s-80----BX0000-----------------------
  166. INT 80 - SoundBlaster SBFM driver - GET VERSION
  167.     BX = 0000h
  168. Return: ???
  169. Note:    SBFM installs at a free interrupt in the range 80h through BFh
  170. SeeAlso: BX=0008h"SBFM",INT 2F/AX=FBFBh/ES=0000h
  171. --------s-80----BX0000-----------------------
  172. INT 80 - SBSIM - "QUERYVERSION" - GET VERSION
  173.     BX = 0000h
  174. Return: AX = version (AH = major, AL = minor)
  175. Program: SBSIM is Creative Labs' SoundBlaster Simplified Interface Module,
  176.       which provides access to multiple drivers for the SoundBlaster
  177.       board through a single interface
  178. Range:    INT 80h to INT BFh, selected automatically
  179. Note:    the SBSIM installation check consists of testing for the signature
  180.       "SBSIM" at offset 103h in the interrupt handler's segment.
  181. SeeAlso: BX=0001h"SBSIM",BX=0005h"SBSIM",INT 21/AX=4402h"CTMMSYS"
  182. SeeAlso: INT 80/BL=00h"SBSIM"
  183. Index:    installation check;SBSIM|installation check;SoundBlaster
  184. --------s-80----BX0001-----------------------
  185. INT 80 - SoundBlaster SBFM driver - SET MUSIC STATUS BYTE ADDRESS
  186.     BX = 0001h
  187.     DX:AX -> music status byte
  188. SeeAlso: BX=0000h"SBFM",BX=0002h"SBFM",BX=0003h"SBFM"
  189. --------s-80----BX0001-----------------------
  190. INT 80 - SBSIM - "QUERYDRIVERS" - CHECK DRIVERS INSTALLED
  191.     BX = 0001h
  192. Return: AX = bit flags for loaded drivers (see #3222)
  193. SeeAlso: BX=0000h"SBSIM",BX=0002h"SBSIM",BX=0005h"SBSIM",INT 80/BL=00h"SBSIM"
  194.  
  195. Bitfields for SBSIM loaded drivers:
  196. Bit(s)    Description    (Table 3222)
  197.  0    FM
  198.  1    double disk-buffered voice driver (DDBV)
  199.  2    memory voice driver
  200.  3    auxiliary driver (mixer)
  201.  4    MIDI
  202. --------s-80----BX0002-----------------------
  203. INT 80 - SoundBlaster SBFM driver - SET INSTRUMENT TABLE
  204.     BX = 0002h
  205.     CX = number of instruments
  206.     DX:AX -> instrument table
  207. SeeAlso: BX=0000h"SBFM",BX=0001h"SBFM",BX=0005h"SBFM"
  208. --------s-80----BX0002-----------------------
  209. INT 80 - SBSIM - GETADDRESS" - GET SELECTED DRIVER'S ENTRY POINT
  210.     BX = 0002h
  211.     AX = driver (00h = FM,01h = DDBV,02h = memvoice,03h = mixer,04h = MIDI)
  212. Return: CF clear if successful
  213.         DX:AX -> entry point
  214.     CF set on error
  215. SeeAlso: BX=0000h"SBSIM",BX=0001h"SBSIM",BX=0005h"SBSIM",INT 80/BL=00h"SBSIM"
  216. --------s-80----BX0003-----------------------
  217. INT 80 - SoundBlaster SBFM driver - SET SYSTEM CLOCK RATE
  218.     BX = 0003h
  219.     AX = clock rate divisor (1193180 / desired frequency in Hertz)
  220.         FFFFh to restore to 18.2 Hz
  221. SeeAlso: BX=0000h"SBFM",BX=0001h"SBFM",BX=0004h"SBFM"
  222. --------s-80----BX0004-----------------------
  223. INT 80 - SoundBlaster SBFM driver - SET DRIVER CLOCK RATE
  224.     BX = 0004h
  225.     AX = driver clock rate divisor (1193180 / frequency in Hertz)
  226. Note:    default frequency is 96 Hz
  227. SeeAlso: BX=0000h"SBFM",BX=0003h"SBFM"
  228. --------s-80----BX0005-----------------------
  229. INT 80 - SoundBlaster SBFM driver - TRANSPOSE MUSIC
  230.     BX = 0005h
  231.     AX = semi-tone offset
  232. SeeAlso: BX=0000h"SBFM",BX=0002h"SBFM",BX=0006h"SBFM"
  233. --------s-80----BX0005-----------------------
  234. INT 80 - SBSIM - "GETBUFFERINFO" - GET DRIVER'S BUFFER ADDRESS
  235.     BX = 0005h
  236.     AX = driver (00h = FM, 01h = DDB Voice, 04h = MIDI)
  237. Return: CF clear if successful
  238.         DX:AX -> buffer
  239.         CX = buffer size in K
  240.     CF set on error
  241. Program: SBSIM is Creative Labs' SoundBlaster Simplified Interface Module,
  242.       which provides access to multiple drivers for the SoundBlaster
  243.       board through a single interface
  244. Range:    INT 80h to INT BFh, selected automatically
  245. Note:    the SBSIM installation check consists of testing for the signature
  246.       "SBSIM" at offset 103h in the interrupt handler's segment.
  247. SeeAlso: BX=0000h"SBSIM",BX=0001h"SBSIM",BX=0002h"SBSIM",INT 80/BL=00h"SBSIM"
  248. --------s-80----BX0006-----------------------
  249. INT 80 - SoundBlaster SBFM driver - PLAY MUSIC
  250.     BX = 0006h
  251.     DX:AX -> music block
  252. Return: AX = status
  253.         0000h successful
  254.         0001h music already active
  255. SeeAlso: BX=0000h"SBFM",BX=0007h"SBFM",BX=000Ah"SBFM",INT 1A/AX=FF04h
  256. --------s-80----BX0007-----------------------
  257. INT 80 - SoundBlaster SBFM driver - STOP MUSIC
  258.     BX = 0007h
  259. Return: AX = status
  260.         0000h successful
  261.         0001h music not active
  262. SeeAlso: BX=0000h"SBFM",BX=0006h"SBFM",BX=0009h"SBFM",INT 1A/AX=FF05h
  263. --------s-80----BX0008-----------------------
  264. INT 80 - SoundBlaster SBFM driver - RESET DRIVER
  265.     BX = 0008h
  266. Return: AX = status
  267.         0000h successful
  268.         0001h music is active
  269. SeeAlso: BX=0000h"SBFM"
  270. --------s-80----BX0009-----------------------
  271. INT 80 - SoundBlaster SBFM driver - PAUSE MUSIC
  272.     BX = 0009h
  273. Return: AX = status
  274.         0000h successful
  275.         0001h no music active
  276. SeeAlso: BX=0000h"SBFM",BX=0007h"SBFM",BX=000Ah"SBFM",INT 1A/AX=FF01h
  277. --------s-80----BX000A-----------------------
  278. INT 80 - SoundBlaster SBFM driver - RESUME MUSIC
  279.     BX = 000Ah
  280. Return: AX = status
  281.         0000h successful
  282.         0001h no music paused
  283. SeeAlso: BX=0000h"SBFM",BX=0006h"SBFM",BX=0009h"SBFM"
  284. --------s-80----BX000B-----------------------
  285. INT 80 - SoundBlaster SBFM driver - SET USER-DEF TRAP FOR SYSTEM-EXCLUSIVE CMDS
  286.     BX = 000Bh
  287.     DX:AX -> trap routine
  288. SeeAlso: BX=0000h"SBFM"
  289. --------s-80----BX0400-----------------------
  290. INT 80 - SBSIM - "GETVOLUME" - GET SOURCE'S VOLUME
  291.     BX = 0400h
  292.     AX = sound source (see #3223)
  293. Return: CF clear if successful
  294.         AX = volume
  295.     CF set on error
  296.         AX = error code (see #3221 at INT 80/BL=00h)
  297. SeeAlso: BX=0401h"SBSIM"
  298.  
  299. (Table 3223)
  300. Values for SBSIM sound source:
  301.  00h    master volume
  302.  01h    voice
  303.  02h    FM
  304.  03h    CD
  305.  04h    line in
  306.  05h    microphone
  307. --------s-80----BX0401-----------------------
  308. INT 80 - SBSIM - "SETVOLUME" - SET SOURCE'S VOLUME
  309.     BX = 0401h
  310.     AX = sound source (see #3223)
  311.     DX = new volume
  312. Return: AX = result (0000h = success) (see also INT 80/BL=00h)
  313. SeeAlso: BX=0400h"SBSIM"
  314. --------N-8001-------------------------------
  315. INT 80 - QPC Software PKTINT.COM - INITIALIZE
  316.     AH = 01h
  317. Return: AX = 0000h
  318.     CX = FFFFh
  319.     DX = FFFFh
  320. Notes:    this interrupt is the WinQVTNet protected mode interface to Windows 3.0
  321.     all buffer pointers are reset back to 0
  322. --------N-8002-------------------------------
  323. INT 80 - QPC Software PKTINT.COM - GET BUFFER ADDRESSES
  324.     AH = 02h
  325.     BX = extra bytes to allocate per packet
  326. Return: AX = segment address of 10K buffer (for receives???)
  327.     BX = segment address of 2K buffer (for sends???)
  328. SeeAlso: AH=05h
  329. --------N-8003-------------------------------
  330. INT 80 - QPC Software PKTINT.COM - GET ENTRY POINT
  331.     AH = 03h
  332. Return: CX:DX -> receive call address
  333. Note:    the returned address can be used in the packet driver calls since it
  334.       will be a valid address in all DOS boxes
  335. SeeAlso: AH=06h
  336. --------N-8004-------------------------------
  337. INT 80 - QPC Software PKTINT.COM - ENABLE???
  338.     AH = 04h
  339.     BX = ???
  340. Return: ???
  341. SeeAlso: AH=01h
  342. --------N-8005-------------------------------
  343. INT 80 - QPC Software PKTINT.COM - GET RECEIVE STATISTICS
  344.     AH = 05h
  345. Return: AX = amount of buffer currently in use
  346.     BX = current offset in buffer
  347.     CX = number of times receive has been called
  348. SeeAlso: AH=02h
  349. --------N-8006-------------------------------
  350. INT 80 - QPC Software PKTINT.COM - REMOVE RECEIVED PACKET
  351.     AH = 06h
  352. Return: BX = next packet offset
  353.     CX = number of bytes still buffered
  354.     DX = size of packet released back into buffer pool
  355. SeeAlso: AH=03h
  356. --------r-81---------------------------------
  357. INT 81 - reserved for BASIC
  358. Note:    this vector is modified but not restored by Direct Access v4.0, and
  359.       may be left dangling by other programs written with the same version
  360.       of compiled BASIC
  361. SeeAlso: INT 80"BASIC",INT 82"BASIC"
  362. --------N-81---------------------------------
  363. INT 81 - IBM TOKEN RING ADAPTER - ???
  364. SeeAlso: INT 82"TOKEN RING",INT 91"TOKEN RING"
  365. --------d-81---------------------------------
  366. INT 81 - BusLogic BT-946C PCI SCSI Adapter - SCRATCHPAD RAM (NOT A VECTOR!)
  367. Note:    the factory-default location for the eight bytes of scratchpad RAM
  368.       needed by the SCSI adapter is 0000h:0200h, which is interrupt
  369.       vectors 80h and 81h
  370. SeeAlso: INT 80"BusLogic"
  371. --------b-81---------------------------------
  372. INT 81 - AMI WinBIOS - SECOND HARD DRIVE AUTODETECTION
  373. Notes:    used by WinBIOS with core version of July 1994 or later
  374.     QEMM 7.5 began using this interrupt internally after the QPAT3
  375.       maintenance release when searching for "ROM holes", causing a
  376.       lengthy delay during bootup.    Adding the QEMM parameter RH:N will
  377.       avoid the QEMM call to INT 81 and speed up the boot process
  378. --------s-810200---------------------------
  379. INT 81 - Gravis UltraSound - MegaEm - PROCESS COMMAND LINE
  380.     AX = 0200h
  381.     BX = PSP segment
  382.     SI = ??? (data area)
  383. Return: AX = status (see #3224)
  384.     BL = emulation state
  385.         bit 1   Emulation is on
  386.         bit 2   Emulation is off
  387. Program: MegaEm is a protected-mode SoundBlaster, SoundCanvas, and MT-32
  388.       emulator for the Gravis UltraSound
  389. Range:    INT ??? to INT ??? (see INT 21/AX=FD12h)
  390. SeeAlso: AX=0202h,AX=0300h,AX=0400h,INT 21/AX=FD12h/BX=3457h
  391.  
  392. (Table 3224)
  393. Values for MegaEm status:
  394.  0000h    successful
  395.  0001h    invalid command line optie
  396.  0002h    display options
  397.  0003h    ???
  398.  0004h    invalid number of voices specified
  399.  0005h    could not load enough patches to provide acceptable emulation
  400.  0006h    to many warnings on patch loading
  401.  0007h    ??? (not used anymore)
  402.  0008h    /CO and SCSI don't work together
  403.  0009h    invalid music volume
  404.  000Ah    invalid master volume
  405.  000Bh    /SC switch is no longer valid
  406.  0100h    ??? (some error on patch loading)
  407. --------s-810202---------------------------
  408. INT 81 - Gravis UltraSound - MegaEm - ???
  409.     AX = 0202h
  410. Return: AX = ???
  411. SeeAlso: AX=0200h,AX=0300h,AX=0400h,INT 21/AX=FD12h/BX=3457h
  412. --------s-810300---------------------------
  413. INT 81 - Gravis UltraSound - MegaEm - LOAD SAMPLE ???
  414.     AX = 0300h
  415. Return: AX = ???
  416. SeeAlso: AX=0200h,AX=0202h,AX=0400h,INT 21/AX=FD12h/BX=3457h
  417. --------s-810400---------------------------
  418. INT 81 - Gravis UltraSound - MegaEm - ???
  419.     AX = 0400h
  420.     BX = ??? (segment)
  421. Return: AX = ???
  422.     BX = ???
  423. Program: MegaEm is a protected-mode SoundBlaster, SoundCanvas, and MT-32
  424.       emulator for the Gravis UltraSound
  425. SeeAlso: AX=0200h,AX=0202h,AX=0300h,INT 21/AX=FD12h/BX=3457h
  426. --------s-812010------------------------
  427. INT 81 - Gravis UltraSound - MEGA_EM v3.0+ - ???
  428.     AX = 2010h
  429.     ???
  430. Return: ???
  431. --------s-812011------------------------
  432. INT 81 - Gravis UltraSound - MEGA_EM v3.0+ - ???
  433.     AX = 2011h
  434.     ???
  435. Return: ???
  436. --------s-812012------------------------
  437. INT 81 - Gravis UltraSound - MEGA_EM v3.0+ - ???
  438.     AX = 2012h
  439.     ???
  440. Return: ???
  441. --------s-812015------------------------
  442. INT 81 - Gravis UltraSound - MEGA_EM v3.0+ - ???
  443.     AX = 2015h
  444.     ???
  445. Return: ???
  446. --------r-82---------------------------------
  447. INT 82 - reserved for BASIC
  448. SeeAlso: INT 81"BASIC",INT 83"BASIC"
  449. --------N-82---------------------------------
  450. INT 82 - IBM TOKEN RING ADAPTER - ???
  451.     AH = function
  452.         00h display message???
  453.         DS:BX -> string
  454.     ???
  455. Return: ???
  456. SeeAlso: INT 81"TOKEN RING",INT 91"TOKEN RING"
  457. --------r-83---------------------------------
  458. INT 83 - reserved for BASIC
  459. SeeAlso: INT 82"BASIC",INT 84"BASIC"
  460. --------s-8300-------------------------------
  461. INT 83 - JM Pro Tracker v5.0 - ???
  462.     AH = 00h
  463.     ???
  464. Return: CF clear (successful)
  465.     AX = ??? (0302h)
  466. Program: JM Pro Tracker is a public-domain resident .MOD (digital music)
  467.       player by Josha Munnik
  468.  
  469. (Table 3225)
  470. Values for JM Pro Tracker error code:
  471.  000Ah    ???
  472.  000Bh    ???
  473.  0014h    ???
  474.  001Eh    some required parameters have not yet been set
  475.  001Fh    already playing???
  476.  FExxh    busy (API call already in progress)
  477.  FFxxh    invalid function number
  478. --------s-8301-------------------------------
  479. INT 83 - JM Pro Tracker v5.0 - ???
  480.     AH = 01h
  481.     DX = ??? or FFFFh
  482.     ???
  483. Return: CF clear if successful
  484.     CF set on error
  485.         AX = error code (see #3225)
  486. --------s-8302-------------------------------
  487. INT 83 - JM Pro Tracker v5.0 - ???
  488.     AH = 02h
  489.     BX = ???
  490.     ???
  491. Return: CF clear if successful
  492.         AX = ???
  493.         BX = ???
  494.         CX = ???
  495.         DX = ???
  496.         SI = ???
  497.     CF set on error
  498.         AX = error code (000Ah,000Bh,other) (see #3225)
  499. --------s-8303-------------------------------
  500. INT 83 - JM Pro Tracker v5.0 - ???
  501.     AH = 03h
  502.     BX = ??? (only low four bits, must be nonzero)
  503.     CX = ???
  504.     ???
  505. Return: CF clear if successful
  506.     CF set on error
  507.         AX = error code (0014h) (see #3225)
  508. --------s-8304-------------------------------
  509. INT 83 - JM Pro Tracker v5.0 - SET DMA BUFFER???
  510.     AH = 04h
  511.     CX = number of bytes in suggested buffer
  512.     ES:DI -> suggested buffer for DMA transfers???
  513. Return: CF clear if successful
  514.         ES:AX -> actual buffer (filled with bytes of 80h)
  515.         CX = actual length (multiple of 4)
  516.     CF set on error
  517.         AX = error code (see #3225)
  518. Note:    the buffer must not cross a 64K DMA page boundary
  519. --------s-8305-------------------------------
  520. INT 83 - JM Pro Tracker v5.0 - SET ??? BUFFER
  521.     AH = 05h
  522.     CX = length of buffer
  523.     ES:DI -> buffer for/containing ???
  524. Return: CF clear (successful)
  525. SeeAlso: AH=06h,AH=07h,AH=18h
  526. --------s-8306-------------------------------
  527. INT 83 - JM Pro Tracker v5.0 - SET ??? BUFFER
  528.     AH = 06h
  529.     CX = length of buffer
  530.     ES:DI -> buffer for/containing ???
  531. Return: CF clear (successful)
  532. SeeAlso: AH=05h,AH=07h,AH=18h
  533. --------s-8307-------------------------------
  534. INT 83 - JM Pro Tracker v5.0 - SET ??? BUFFER
  535.     AH = 07h
  536.     BX = ???
  537.     CX = length of buffer
  538.     ES:DI -> buffer for/containing ???
  539. Return: CF clear (successful)
  540. SeeAlso: AH=05h,AH=06h,AH=18h
  541. --------s-8308-------------------------------
  542. INT 83 - JM Pro Tracker v5.0 - START PLAYING???
  543.     AH = 08h
  544.     ???
  545. Return: CF clear if successful
  546.        ???
  547.     CF set on error
  548.         AX = error code (001Eh,001Fh) (see #3225)
  549. SeeAlso: AH=09h,AH=0Ah
  550. --------s-8309-------------------------------
  551. INT 83 - JM Pro Tracker v5.0 - PAUSE???
  552.     AH = 09h
  553.     ???
  554. Return: CF clear if successful
  555.     CF set on error
  556.         AX = error code (see #3225)
  557. SeeAlso: AH=08h,AH=0Ah
  558. --------s-830A-------------------------------
  559. INT 83 - JM Pro Tracker v5.0 - RESUME???
  560.     AH = 0Ah
  561.     ???
  562. Return: CF clear if successful
  563.     CF set on error
  564.         AX = error code (001Fh) (see #3225)
  565. SeeAlso: AH=08h,AH=09h
  566. --------s-830B-------------------------------
  567. INT 83 - JM Pro Tracker v5.0 - ???
  568.     AH = 0Bh
  569.     BX = ???
  570.     ???
  571. Return: CF clear if successful
  572.     CF set on error
  573. --------s-830C-------------------------------
  574. INT 83 - JM Pro Tracker v5.0 - ???
  575.     AH = 0Ch
  576.     DX bit 5 = ???
  577.     ???
  578. Return: CF clear if successful
  579.         BX = ??? (FFFFh)
  580.         CX = ??? (0000h)
  581.         DX = ???
  582.     CF set on error
  583.         AX = error code (see #3225)
  584. --------s-830D-------------------------------
  585. INT 83 - JM Pro Tracker v5.0 - ???
  586.     AH = 0Dh
  587.     BX = ???
  588.     ???
  589. Return: CF clear (successful)
  590. --------s-830E-------------------------------
  591. INT 83 - JM Pro Tracker v5.0 - ???
  592.     AH = 0Eh
  593.     BX = ??? (ignored if ES:DI = 0000h:0000h)
  594.     ES:DI -> ??? or 0000h:0000h
  595. Return: CF clear (successful)
  596. --------s-830F-------------------------------
  597. INT 83 - JM Pro Tracker v5.0 - ???
  598.     AH = 0Fh
  599.     ???
  600. Return: CF clear if successful
  601.         AX = ???
  602.     CF set on error
  603.         AX = error code (see #3225)
  604. --------s-8310-------------------------------
  605. INT 83 - JM Pro Tracker v5.0 - ???
  606.     AH = 10h
  607.     BL = subfunction???
  608.     CX = ???
  609.     DX = ???
  610.     ???
  611. Return: CF clear if successful
  612.         CX = DX = ???
  613.     CF set on error
  614.         AX = error code (see #3225)
  615. SeeAlso: AH=18h
  616. --------s-8311-------------------------------
  617. INT 83 - JM Pro Tracker v5.0 - ???
  618.     AH = 11h
  619.     BL = ???
  620.     CX = ???
  621. Return: CF clear (successful)
  622. --------s-8312-------------------------------
  623. INT 83 - JM Pro Tracker v5.0 - CLEAR ???
  624.     AH = 12h
  625. Return: nothing
  626. --------s-8313-------------------------------
  627. INT 83 - JM Pro Tracker v5.0 - ???
  628.     AH = 13h
  629.     BX = ???
  630. Return: CF clear (successful)
  631. --------s-8314-------------------------------
  632. INT 83 - JM Pro Tracker v5.0 - ???
  633.     AH = 14h
  634.     ???
  635. Return: CF clear (successful)
  636.     BX = ???
  637. --------s-8315-------------------------------
  638. INT 83 - JM Pro Tracker v5.0 - GET ???
  639.     AH = 15h
  640.     BX = what to get (zero/nonzero)
  641. Return: CF clear if successful
  642.         BX = ???
  643.         DX = ???
  644.     CF set on error
  645.         AX = error code (see #3225)
  646. --------s-8316-------------------------------
  647. INT 83 - JM Pro Tracker v5.0 - ???
  648.     AH = 16h
  649.     AL = subfunction
  650.         00h ???
  651.         Return: BX = ???
  652.             CX = ???
  653.             DX = ???
  654.             ES:DI -> ???
  655.             CF indicates ???
  656.         01h ???
  657.         Return: BX = ???
  658.             CX = ???
  659.             DX = ???
  660. Return: CF clear if successful
  661.     CF set on error
  662.         AX = error code (FFxxh) (see #3225)
  663. --------s-8317-------------------------------
  664. INT 83 - JM Pro Tracker v5.0 - UNHOOK API INTERRUPT
  665.     AH = 17h
  666. Return: CF clear if successful
  667.     CF set on error (hooked by another program)
  668. --------s-8318-------------------------------
  669. INT 83 - JM Pro Tracker v5.0 - SET BUFFERS
  670.     AH = 18h
  671.     ES:DI -> buffer-pointer structure (see #3226)
  672. Return: nothing
  673. SeeAlso: AH=05h,AH=06h,AH=07h,AH=10h
  674.  
  675. Format of JM Pro Tracker buffer-pointer structure:
  676. Offset    Size    Description    (Table 3226)
  677.  00h    WORD    length of ??? buffer (see AH=05h)
  678.  02h    DWORD    -> ??? buffer (see AH=05h)
  679.  06h    WORD    length of ??? buffer (see AH=06h)
  680.  08h    DWORD    -> ??? buffer (see AH=06h)
  681.  0Ch    WORD    length of ??? buffer (see AH=07h)
  682.  0Eh    DWORD    -> ??? buffer (see AH=07h)
  683.  12h    WORD    ??? (see AH=07h)
  684.  14h    WORD    ??? (see AH=10h) (subfunction 01h)
  685.  16h    WORD    ??? (see AH=10h) (subfunction 01h)
  686.  18h    WORD    ??? (see AH=10h) (subfunction 00h)
  687.  1Ah    WORD    ??? (see AH=10h) (subfunction 01h)
  688. --------r-84---------------------------------
  689. INT 84 - reserved for BASIC
  690. SeeAlso: INT 83"BASIC",INT 85"BASIC"
  691. --------r-85---------------------------------
  692. INT 85 - reserved for BASIC
  693. Note:    INT 80 through INT ED are modified but not restored by Direct Access
  694.       v4.0, and may be left dangling by other programs written with the
  695.       same version of compiled BASIC
  696. SeeAlso: INT 84"BASIC",INT 86"BASIC"
  697. --------N-86---------------------------------
  698. INT 86 - NetBIOS - ORIGINAL INT 18
  699. Note:    some implementations of NetBIOS reportedly relocate INT 18 here
  700. SeeAlso: INT 18"BOOT HOOK"
  701. --------r-86---------------------------------
  702. INT 86 - IBM ROM BASIC - used while in interpreter
  703. Notes:    called by ROM BASIC, but pointed at IRET by BASIC.COM/BASICA.COM
  704.     BASIC.COM/BASICA.COM do not restore vector on termination
  705. SeeAlso: INT 85"BASIC",INT 87"BASIC"
  706. --------r-86---------------------------------
  707. INT 86 - APL*PLUS/PC - Terminate APL session and return to DOS
  708. SeeAlso: INT 21/AH=4Ch,INT 87"APL"
  709. --------r-87---------------------------------
  710. INT 87 - IBM ROM BASIC - used while in interpreter
  711. Notes:    called by ROM BASIC
  712.     BASIC.COM/BASICA.COM do not restore vector on termination
  713. SeeAlso: INT 86"BASIC",INT 88"BASIC"
  714. --------r-87---------------------------------
  715. INT 87 - APL*PLUS/PC - ???
  716. SeeAlso: INT 86"APL",INT 88/AL=00h
  717. --------v-87---------------------------------
  718. INT 87 - VIRUS - "ZeroHunt" - VIRAL CODE (NOT A VECTOR!)
  719. Note:    the ZeroHunt virus copies its resident code down to 0000h:021Ch and
  720.       following
  721. SeeAlso: INT 8B"VIRUS"
  722. --------r-88---------------------------------
  723. INT 88 - IBM ROM BASIC - used while in interpreter
  724. Notes:    called by ROM BASIC, but pointed at IRET by BASIC.COM/BASICA.COM
  725.     BASIC.COM/BASICA.COM do not restore vector on termination
  726. SeeAlso: INT 87"BASIC",INT 89"BASIC"
  727. --------r-88--00-----------------------------
  728. INT 88 - APL*PLUS/PC - CREATE OBJECT OF ARBITRARY RANK OR SHAPE
  729.     AL = 00h
  730.     BX = STPTR of the variable to be assigned
  731.     ES:SI -> model of type, rank, and shape (see #3227)
  732. Return: ES:DI -> first data byte of object
  733.     DX:CX = number of elements in the object
  734. SeeAlso: INT C8"APL"
  735.  
  736. Format of APL*PLUS/PC shape model:
  737. Offset    Size    Description    (Table 3227)
  738.  00h    BYTE    type
  739.         01h character (2-byte dimension sizes)
  740.         02h integer (2-byte dimension sizes)
  741.         08h floating point (2-byte dimension sizes)
  742.         11h character (4-byte dimension sizes)
  743.         12h integer (4-byte dimension sizes)
  744.         18h floating point (4-byte dimension sizes)
  745.  01h    BYTE    rank
  746.  02h    (D)WORD first dimension of shape
  747.  N    (D)WORD second dimension of shape
  748.     ...
  749. --------r-88--01-----------------------------
  750. INT 88 - APL*PLUS/PC - CREATE CHARACTER SCALAR/VECTOR/MATRIX <64K IN SIZE
  751.     AL = 01h
  752.     AH = rank
  753.     BX = STPTR of the variable to be assigned
  754.     CX = first dimension (if any)
  755.     DX = second dimension (if any)
  756. Return: ES:DI -> object
  757.     CX = number of elements in the object
  758. Note:    each dimension must be 32767 or smaller
  759. SeeAlso: AL=02h,AL=08h,INT C8"APL"
  760. --------r-88--02-----------------------------
  761. INT 88 - APL*PLUS/PC - CREATE INTEGER SCALAR/VECTOR/MATRIX <64K IN SIZE
  762.     AL = 02h
  763.     AH = rank
  764.     BX = STPTR of the variable to be assigned
  765.     CX = first dimension (if any)
  766.     DX = second dimension (if any)
  767. Return: ES:DI -> object
  768.     CX = number of elements in the object
  769. Note:    each dimension must be 32767 or smaller
  770. SeeAlso: AL=01h,AL=08h,INT C8"APL"
  771. --------r-88--08-----------------------------
  772. INT 88 - APL*PLUS/PC - CREATE FLOATING POINT SCALAR/VECTOR/MATRIX <64K IN SIZE
  773.     AL = 08h
  774.     AH = rank
  775.     BX = STPTR of the variable to be assigned
  776.     CX = first dimension (if any)
  777.     DX = second dimension (if any)
  778. Return: ES:DI -> object
  779.     CX = number of elements in the object
  780. Note:    each dimension must be 32767 or smaller
  781. SeeAlso: AL=01h,AL=02h,INT C8"APL"
  782. --------r-88--F5-----------------------------
  783. INT 88 - APL*PLUS/PC - FORCE OBJECT INTO REAL WORKSPACE FROM VIRTUAL
  784.     AL = F5h
  785.     BX = STPTR of object
  786. SeeAlso: INT C8"APL"
  787. --------r-88--F6-----------------------------
  788. INT 88 - APL*PLUS/PC - MAKE NAME IMMUNE FROM OUTSWAPPING
  789.     AL = F6h
  790.     BX = STPTR of object
  791. SeeAlso: AL=F7h,AL=F8h,INT C8"APL"
  792. --------r-88--F7-----------------------------
  793. INT 88 - APL*PLUS/PC - MAKE NAME ELIGIBLE FOR OUTSWAPPING
  794.     AL = F7h
  795.     BX = STPTR of object
  796. SeeAlso: AL=F6h,AL=F8h,INT C8"APL"
  797. --------r-88--F8-----------------------------
  798. INT 88 - APL*PLUS/PC - REPORT WHETHER NAME IS ELIGIBLE FOR OUTSWAPPING
  799.     AL = F8h
  800.     BX = STPTR of object
  801. Return: BX = name's outswapping status
  802.         0000h eligible
  803.         0001h not eligible
  804. SeeAlso: AL=F6h,AL=F7h,INT C8"APL"
  805. --------r-88--F9-----------------------------
  806. INT 88 - APL*PLUS/PC - DETERMINE NAME STATUS
  807.     AL = F9h
  808.     ES:SI -> name
  809.     CX = length of name
  810. Return: CF set if name ill-formed or already in use
  811.         BX = STPTR if already in symbol table
  812.     CF clear if name is available for use
  813.         BX = 0000h
  814. Note:    does not force the name into the workspace
  815. SeeAlso: AL=FEh,AL=FFh,INT C8"APL"
  816. --------r-88--FC-----------------------------
  817. INT 88 - APL*PLUS/PC - DETERMINE IF MEMORY AVAIL WITHOUT GARBAGE COLLECTION
  818.     AL = FCh
  819.     BX = amount of memory needed (paragraphs)
  820. Return: CF clear if memory available
  821.     CF set if a workspace compaction is required
  822. SeeAlso: AL=FDh,INT C8"APL"
  823. --------r-88--FD-----------------------------
  824. INT 88 - APL*PLUS/PC - PERFORM GARBAGE COLLECTION AND RETURN AVAILABLE MEMORY
  825.     AL = FDh
  826. Return: BX = number of paragraphs available in workspace
  827. SeeAlso: AL=FCh,INT C8"APL"
  828. --------r-88--FE-----------------------------
  829. INT 88 - APL*PLUS/PC - CREATE NAME
  830.     AL = FEh
  831.     ES:SI -> name
  832.     CX = length of name
  833. Return: BX = STPTR of name
  834.     DX = interpreter's data segment
  835. SeeAlso: AL=F9h,AL=FFh,INT C8"APL"
  836. --------r-88--FF-----------------------------
  837. INT 88 - APL*PLUS/PC - DETERMINE NAME STATUS
  838.     AL = FFh
  839.     ES:SI -> name
  840.     CX = length of name
  841. Return: CF set if name ill-formed or already in use
  842.         BX = STPTR if already in symbol table
  843.     CF clear if name is available for use
  844.         BX = 0000h
  845. Note:    forces the name into the workspace and makes it immune from outswapping
  846. SeeAlso: AL=F9h,AL=FEh,INT C8"APL"
  847. --------r-89---------------------------------
  848. INT 89 - IBM ROM BASIC - used while in interpreter
  849. Notes:    called by ROM BASIC
  850.     BASIC.COM/BASICA.COM do not restore vector on termination
  851. SeeAlso: INT 88"BASIC",INT 8A"BASIC"
  852. --------r-89---------------------------------
  853. INT 89 - APL*PLUS/PC - ???
  854. Note:    STSC moved its interrupts from 86h-8Ch to C6h-CCh, but did not delete
  855.       the older interrupts
  856. SeeAlso: INT C9"APL"
  857. --------r-8A---------------------------------
  858. INT 8A - IBM ROM BASIC - used while in interpreter
  859. Notes:    called by ROM BASIC
  860.     BASIC.COM/BASICA.COM do not restore vector on termination
  861. SeeAlso: INT 89"BASIC",INT 8B"BASIC"
  862. --------r-8A---------------------------------
  863. INT 8A - APL*PLUS/PC - PRINT SCREEN
  864. Note:    same as INT 05
  865. SeeAlso: INT 05"PRINT SCREEN",INT 8C"APL",INT CA"APL"
  866. --------r-8B---------------------------------
  867. INT 8B - IBM ROM BASIC - used while in interpreter
  868. Notes:    called by ROM BASIC, but pointed at IRET by BASIC.COM/BASICA.COM
  869.     BASIC.COM/BASICA.COM do not restore vector on termination
  870. SeeAlso: INT 8A"BASIC",INT 8C"BASIC"
  871. --------r-8B---------------------------------
  872. INT 8B - APL*PLUS/PC - BEEP
  873. Note:    same as printing a ^G via INT 21/AH=02h
  874. SeeAlso: INT 21/AH=02h,INT CB"APL"
  875. --------v-8B---------------------------------
  876. INT 8B - VIRUS - "ZeroHunt" - INSTALLATION CHECK (NOT A VECTOR!)
  877. Note:    if the ZeroHunt virus is resident, this vector will contain either
  878.       EE83h:019Bh (ZH-411) or EE83h:019Fh (ZH-415)
  879. SeeAlso: INT 70"VIRUS",INT 87"VIRUS",INT 9C"VIRUS"
  880. --------r-8C---------------------------------
  881. INT 8C - IBM ROM BASIC - used while in interpreter
  882. Notes:    called by ROM BASIC, but pointed at IRET by BASIC.COM/BASICA.COM
  883.     BASIC.COM/BASICA.COM do not restore vector on termination
  884. --------r-8C---------------------------------
  885. INT 8C - APL*PLUS/PC - CLEAR SCREEN MEMORY
  886.     AX = flag
  887.         0000h do not save display attributes
  888.         0001h save attributes
  889. SeeAlso: INT CC"APL"
  890. --------r-8D---------------------------------
  891. INT 8D - IBM ROM BASIC - used while in interpreter
  892. Notes:    called by ROM BASIC, but pointed at IRET by BASIC.COM/BASICA.COM
  893.     BASIC.COM/BASICA.COM do not restore vector on termination
  894. --------r-8E---------------------------------
  895. INT 8E - IBM ROM BASIC - used while in interpreter
  896. Notes:    called by ROM BASIC, but pointed at IRET by BASIC.COM/BASICA.COM
  897.     BASIC.COM/BASICA.COM do not restore vector on termination
  898. --------r-8F---------------------------------
  899. INT 8F - IBM ROM BASIC - used while in interpreter
  900. Notes:    called by ROM BASIC, but pointed at IRET by BASIC.COM/BASICA.COM
  901.     BASIC.COM/BASICA.COM do not restore vector on termination
  902. --------r-90---------------------------------
  903. INT 90 - IBM ROM BASIC - used while in interpreter
  904. Notes:    called by ROM BASIC, but pointed at IRET by BASIC.COM/BASICA.COM
  905.     BASIC.COM/BASICA.COM do not restore vector on termination
  906. --------r-90---------------------------------
  907. INT 90 - APL*PLUS/PC - USED BY PORT 10 PRINTER DRIVER
  908. --------r-91---------------------------------
  909. INT 91 - IBM ROM BASIC - used while in interpreter
  910. Notes:    called by ROM BASIC, but pointed at IRET by BASIC.COM/BASICA.COM
  911.     BASIC.COM/BASICA.COM do not restore vector on termination
  912. --------N-91---------------------------------
  913. INT 91 - IBM TOKEN RING ADAPTER - ???
  914. SeeAlso: INT 81"TOKEN RING",INT 82"TOKEN RING",INT 93"TOKEN RING"
  915. --------r-92---------------------------------
  916. INT 92 - IBM ROM BASIC - used while in interpreter
  917. Notes:    called by ROM BASIC, but pointed at IRET by BASIC.COM/BASICA.COM
  918.     BASIC.COM/BASICA.COM do not restore vector on termination
  919. --------N-92---------------------------------
  920. INT 92 - Sangoma X.25 INTERFACE PROGRAM
  921.     BX:DX -> control block
  922. SeeAlso: INT 68"Sangoma"
  923. --------e-92E1-------------------------------
  924. INT 92 - Da Vinci eMail Dispatcher INTERFACE
  925.     AH = E1h
  926.     AL = function
  927.     BX = stack count (number of words to push)
  928.     CX:DX -> stack data (in word-reversed order ready to push)
  929. Return: AX = status (see #3228)
  930. Note:    preserves BP, DS, SI, DI; other registers may be destroyed
  931.  
  932. (Table 3228)
  933. Values for Da Vinci eMail function status:
  934.  0001h    success
  935.  FF97h    "ERS_NOT_AVAILABLE"
  936.  FF99h    "ERS_TOO_MANY_NAMES"
  937.  FF9Ah    "ERS_BAD_NAME_PASSWORD"
  938.  FFE3h    "ERS_NAME_NOT_FOUND"
  939.  FFF8h    "ERS_USE_STRING" (call NetGetError to get error string)
  940.  FFFFh    "ERS_NO_SUCH_FILE"
  941. --------e-92E100-----------------------------
  942. INT 92 - Da Vinci eMail Dispatcher - "NetInitStart"
  943.     AX = E100h
  944.     BX = size of parameter block in words (000Ah)
  945.     CX:DX -> parameter block (see #3229)
  946. Return: AX = 0001h success
  947. Desc:    this function is used to initialize the dispatcher
  948. SeeAlso: AX=E101h,AX=E103h
  949.  
  950. Format of Da Vinci eMail "NetInitStart" parameter block:
  951. Offset    Size    Description    (Table 3229)
  952.  00h    WORD    segment of ???
  953.  02h    WORD    offset of ???
  954.  04h    WORD    high part of long ???
  955.  06h    WORD    low part of long ???
  956.  08h    WORD    high part of long ???
  957.  0Ah    WORD    low part of long ???
  958.  0Ch    WORD    high part of long ???
  959.  0Eh    WORD    low part of long ???
  960.  10h    WORD    high part of long ???
  961.  12h    WORD    low part of long ???
  962. --------e-92E101BX0000-----------------------
  963. INT 92 - Da Vinci eMail Dispatcher - "NetInitCheck"
  964.     AX = E101h
  965.     BX = 0000h
  966.     CX:DX ignored
  967. Return: AX = 0001h success
  968. SeeAlso: AX=E100h,AX=E180h
  969. --------e-92E102BX0000-----------------------
  970. INT 92 - Da Vinci eMail Dispatcher - "NetCheckDriver"
  971.     AX = E102h
  972.     BX = 0000h
  973.     CX:DX ignored
  974. Return: AX = 0001h success
  975. Desc:    this function is used to determine if the dispatcher is loaded
  976. SeeAlso: AX=E10Bh,AX=E180h
  977. --------e-92E103BX0000-----------------------
  978. INT 92 - Da Vinci eMail Dispatcher - "NetTerminate"
  979.     AX = E103h
  980.     BX = 0000h
  981.     CX:DX ignored
  982. Return: AX = status (see #3228)
  983. SeeAlso: AX=E100h
  984. --------e-92E104-----------------------------
  985. INT 92 - Da Vinci eMail Dispatcher - "NetWhereIs"
  986.     AX = E104h
  987.     BX = size of parameter block in words (0006h)
  988.     CX:DX -> parameter block (see #3230)
  989. Return: AX = status (see #3228)
  990. Desc:    this function is used to verify node address for usernames
  991. SeeAlso: AX=E180h
  992.  
  993. Format of Da Vinci eMail "NetWhereIs" parameter block:
  994. Offset    Size    Description    (Table 3230)
  995.  00h    WORD    segment of node address buffer
  996.  02h    WORD    offset of node address buffer
  997.  04h    WORD    segment of uppercase username
  998.  06h    WORD    offset of uppercase username
  999.  08h    WORD    segment of "DVSEMAIL"
  1000.  0Ah    WORD    offset of "DVSEMAIL"
  1001. --------e-92E105-----------------------------
  1002. INT 92 - Da Vinci eMail Dispatcher - "NetOpen"
  1003.     AX = E105h
  1004.     BX = size of parameter block in words (0007h)
  1005.     CX:DX -> parameter block (see #3231)
  1006. Return: AX = 0000h Error
  1007.     AX = handle
  1008. Desc:    this function is used to open a submission channel
  1009. SeeAlso: AX=E10Ah,AX=E106h,AX=E108h
  1010.  
  1011. Format of Da Vinci eMail "NetOpen" parameter block:
  1012. Offset    Size    Description    (Table 3231)
  1013.  00h    WORD    operation (1 = read, 2 = write)
  1014.  02h    WORD    segment of uppercase To: username
  1015.  04h    WORD    offset of uppercase To: username
  1016.  06h    WORD    segment of "DVSEMAIL"
  1017.  08h    WORD    offset of "DVSEMAIL"
  1018.  0Ah    WORD    segment of node address
  1019.  0Ch    WORD    offset of node address
  1020. --------e-92E106BX0004-----------------------
  1021. INT 92 - Da Vinci eMail Dispatcher - "NetRead"
  1022.     AX = E106h
  1023.     BX = 0004h
  1024.     CX:DX -> parameter block
  1025. Return: AX = 0001h
  1026. SeeAlso: AX=E108h
  1027. --------e-92E107BX0002-----------------------
  1028. INT 92 - Da Vinci eMail Dispatcher - "NetGetError"
  1029.     AX = E107h
  1030.     BX = 0002h
  1031.     CX:DX -> parameter block
  1032. Return: AX = 0001h
  1033. SeeAlso: AX=E109h,AX=E180h
  1034. --------e-92E108-----------------------------
  1035. INT 92 - Da Vinci eMail Dispatcher - "NetWrite"
  1036.     AX = E108h
  1037.     BX = size of parameter block in words (0004h)
  1038.     CX:DX -> parameter block (see #3232)
  1039. Return: AX = amount written
  1040. Desc:    This function is used to write transactions to the dispatcher.
  1041.       The command block is written first and then another call is used
  1042.       to write the associated data.
  1043. SeeAlso: AX=E106h
  1044.  
  1045. Format of Da Vinci eMail "NetWrite" parameter block:
  1046. Offset    Size    Description    (Table 3232)
  1047.  00h    WORD    buffer count (see #3234)
  1048.  02h    WORD    segment of command buffer (see #3233)
  1049.  04h    WORD    offset of command buffer
  1050.  06h    WORD    handle from NetOpen
  1051.  
  1052. Format of Da Vinci eMail command buffer:
  1053. Offset    Size    Description    (Table 3233)
  1054.  00h    BYTE    command
  1055.         21h '!' Protocol commands for remote control
  1056.         41h 'A' Authorization protocol element
  1057.         42h 'B' Return(back) routing information
  1058.             Associated data is the From: username
  1059.         43h 'C' Carbon Copy list
  1060.             Associated data is a comma delimitted list of usernames
  1061.         44h 'D' Distribution list
  1062.             Associated data is a comma delimitted list of usernames
  1063.         45h 'E' Mail end marker
  1064.             No associated data
  1065.         48h 'H' Mail message header
  1066.             Associated data is a message header buffer
  1067.         4Dh 'M' Mail message
  1068.             Associated data is the body of the message
  1069.         4Fh 'O' Object
  1070.         50h 'P' Paperclip attachment
  1071.         52h 'R' Routing information
  1072.             Associated data is the To: username
  1073.         53h 'S' Subject
  1074.             Associated data is the subject of the message
  1075.         54h 'T' Trail of Reply/Forwards
  1076.  01h    BYTE    subcommand
  1077.  02h    DWORD    length of associated data
  1078.  
  1079. Format of Da Vinci eMail message header buffer:
  1080. Offset    Size    Description    (Table 3234)
  1081.  00h 30 BYTEs    subject line
  1082.  1Eh 24 BYTEs    To
  1083.  36h 24 BYTEs    From
  1084.  4Eh    DWORD    Time
  1085.         BYTE    00h
  1086.         BYTE    hour
  1087.         BYTE    minute
  1088.         BYTE    second
  1089.  52h    DWORD    Date
  1090.         BYTE    00h
  1091.         BYTE    year
  1092.         BYTE    month
  1093.         BYTE    day
  1094.  56h    DWORD    serial number (00000000h)
  1095.  5Ah    WORD    mail types (see #3235)
  1096.  5Ch    WORD    special types (0)
  1097.  
  1098. Bitfields for Da Vinci eMail mail types:
  1099. Bit(s)    Description    (Table 3235)
  1100.  7    blind carbon copy
  1101.  6    carbon copy
  1102.  5    priority
  1103.  4    confidential
  1104.  3    certified
  1105.  2    bulk
  1106.  1-0    class (first, second, third, bulk)
  1107. --------e-92E109-----------------------------
  1108. INT 92 - Da Vinci eMail Dispatcher - "NetErrorFix" (UNUSED)
  1109.     AX = E109h
  1110.     BX = size of parameter block in words (0001h)
  1111.     CX:DX -> parameter block (see #3236)
  1112. Return: AX = FF97h (ERS_NOT_AVAILABLE)
  1113. SeeAlso: AX=E107h,AX=E180h
  1114.  
  1115. Format of Da Vinci eMail "NetErrorFix" parameter block:
  1116. Offset    Size    Description    (Table 3236)
  1117.  00h    WORD    ???
  1118. --------e-92E10A-----------------------------
  1119. INT 92 - Da Vinci eMail Dispatcher - "NetClose"
  1120.     AX = E10Ah
  1121.     BX = size of parameter block in words (0001h)
  1122.     CX:DX -> parameter block (see #3237)
  1123. Return: AX = 0001h
  1124. Desc:    this function is used to close a dispatcher handle
  1125. SeeAlso: AX=E105h
  1126.  
  1127. Format of Da Vinci eMail "NetClose" parameter block:
  1128. Offset    Size    Description    (Table 3237)
  1129.  00h    WORD    handle from NetOpen
  1130. --------e-92E10B-----------------------------
  1131. INT 92 - Da Vinci eMail Dispatcher - "NetCheckQueue"
  1132.     AX = E10Bh
  1133.     BX = size of parameter block in words (0004h)
  1134.     CX:DX -> parameter block (see #3238)
  1135. Return: AX = 0001h
  1136. SeeAlso: AX=E102h,AX=E10Ch
  1137.  
  1138. Format of Da Vinci eMail "NetCheckQueue" parameter block:
  1139. Offset    Size    Description    (Table 3238)
  1140.  00h    WORD    segment of 24-byte username buffer
  1141.  02h    WORD    offset of 24-byte username buffer
  1142.  04h    WORD    segment of 24-byte protocol buffer
  1143.  06h    WORD    offset of 24-byte protocol buffer
  1144. --------e-92E10C-----------------------------
  1145. INT 92 - Da Vinci eMail Dispatcher - "NetReadQueue"
  1146.     AX = E10Ch
  1147.     BX = size of parameter block in words (0002h)
  1148.     CX:DX -> parameter block (see #3239)
  1149. Return: AX = 0001h
  1150. SeeAlso: AX=E10Bh
  1151.  
  1152. Format of Da Vinci eMail "NetReadQueue" parameter block:
  1153. Offset    Size    Description    (Table 3239)
  1154.  00h    WORD    Segment of 128 byte node address buffer
  1155.  02h    WORD    Offset of 128 byte node address buffer
  1156. --------e-92E10D-----------------------------
  1157. INT 92 - Da Vinci eMail Dispatcher - "NetSubmitName"
  1158.     AX = E10Dh
  1159.     BX = size of parameter block in words (0006h)
  1160.     CX:DX -> parameter block (see #3240)
  1161. Return: AX = status (see #3228)
  1162. Desc:    this function is used to verify username/password
  1163. SeeAlso: AX=E10Eh
  1164.  
  1165. Format of Da Vinci eMail "NetSubmitName" parameter block:
  1166. Offset    Size    Description    (Table 3240)
  1167.  00h    WORD    segment of uppercase password string
  1168.  02h    WORD    offset of uppercase password string
  1169.  04h    WORD    segment of uppercase username string
  1170.  06h    WORD    offset of uppercase username string
  1171.  08h    WORD    segment of "DVSEMAIL"
  1172.  0Ah    WORD    offset of "DVSEMAIL"
  1173. --------e-92E10E-----------------------------
  1174. INT 92 - Da Vinci eMail Dispatcher - "NetRemoveName"
  1175.     AX = E10Eh
  1176.     BX = size of parameter block in words (0004h)
  1177.     CX:DX -> parameter block (see #3241)
  1178. Return: AX = 0001h
  1179. Desc:    this function is used to remove a username
  1180. SeeAlso: AX=E10Dh
  1181.  
  1182. Format of Da Vinci eMail "NetRemoveName" parameter block:
  1183. Offset    Type    Description    (Table 3241)
  1184.  00h    WORD    segment of uppercase username
  1185.  02h    WORD    offset of uppercase username
  1186.  04h    WORD    segment of "DVSEMAIL"
  1187.  06h    WORD    offset of "DVSEMAIL"
  1188. --------e-92E10FBX0000-----------------------
  1189. INT 92 - Da Vinci eMail Dispatcher - IS ANYONE THERE? QUERY
  1190.     AX = E10Fh
  1191.     BX = 0000h
  1192.     CX:DX ignored
  1193. Return: AX = 0001h
  1194. SeeAlso: AX=E180h
  1195. --------e-92E110-----------------------------
  1196. INT 92 - Da Vinci eMail Dispatcher - "NetGetAltRoute"
  1197.     AX = E110h
  1198.     BX = size of parameter block in words (0006h)
  1199.     CX:DX -> parameter block (see #3242)
  1200. Return: AX = 0001h
  1201. SeeAlso: AX=E111h,AX=E113h
  1202.  
  1203. Format of Da Vinci eMail "NetGetAltRoute" parameter block:
  1204. Offset    Size    Description    (Table 3242)
  1205.  00h  6 WORDs    ???
  1206. --------e-92E111-----------------------------
  1207. INT 92 - Da Vinci eMail Dispatcher - "NetDeleteAltRoutes"
  1208.     AX = E111h
  1209.     BX = size of parameter block in words (0004h)
  1210.     CX:DX -> parameter block (see #3243)
  1211. Return: AX = 0001h
  1212. SeeAlso: AX=E110h,AX=E113h
  1213.  
  1214. Format of Da Vinci eMail "NetDeleteAltRoutes" parameter block:
  1215. Offset    Size    Description    (Table 3243)
  1216.  00h  4 WORDs    ???
  1217. --------e-92E112-----------------------------
  1218. INT 92 - Da Vinci eMail Dispatcher - "NetChangePassword"
  1219.     AX = E112h
  1220.     BX = size of parameter block in words (0008h)
  1221.     CX:DX -> parameter block (see #3244)
  1222. Return: AX = 0001h
  1223. SeeAlso: AX=E180h
  1224.  
  1225. Format of Da Vinci eMail "NetChangePassword" parameter block:
  1226. Offset    Size    Description    (Table 3244)
  1227.  00h  8 WORDs    ???
  1228. --------e-92E113-----------------------------
  1229. INT 92 - Da Vinci eMail Dispatcher - "NetSetAltRoute"
  1230.     AX = E113h
  1231.     BX = size of parameter block in words (0008h)
  1232.     CX:DX -> parameter block (see #3245)
  1233. Return: AX = 0001h
  1234. SeeAlso: AX=E110h,AX=E111h
  1235.  
  1236. Format of Da Vinci eMail "NetSetAltRoute" parameter block:
  1237. Offset    Size    Description    (Table 3245)
  1238.  00h  8 WORDs    ???
  1239. --------e-92E175-----------------------------
  1240. INT 92 - Da Vinci eMail Dispatcher - BECOME MICRO TSR
  1241.     AX = E175h
  1242. Return: AX = 0012h
  1243.     BX = PSP
  1244. SeeAlso: AX=E180h
  1245. --------e-92E180-----------------------------
  1246. INT 92 - Da Vinci eMail Dispatcher - INSTALLATION CHECK
  1247.     AX = E180h
  1248. Return: AX = 0012h if installed
  1249.     ES:DX -> '$'-terminated driver information string
  1250. SeeAlso: AX=E102h,AX=E105h,AX=E10Fh,AX=E175h
  1251. --------r-93---------------------------------
  1252. INT 93 - IBM ROM BASIC - used while in interpreter
  1253. Notes:    called by ROM BASIC
  1254.     BASIC.COM/BASICA.COM do not restore vector on termination
  1255. --------N-93---------------------------------
  1256. INT 93 - IBM TOKEN RING ADAPTER - ???
  1257. SeeAlso: INT 81"TOKEN RING",INT 91"TOKEN RING"
  1258. --------r-94---------------------------------
  1259. INT 94 - IBM ROM BASIC - used while in interpreter
  1260. Notes:    called by ROM BASIC, but pointed at IRET by BASIC.COM/BASICA.COM
  1261.     BASIC.COM/BASICA.COM do not restore vector on termination
  1262. --------s-94----SI0000-----------------------
  1263. INT 94 u - PCM driver - INITIALIZE SOUND
  1264.     SI = 0000h
  1265.     ES:BX -> parameters
  1266. Return: ???
  1267. Program: PCM.COM is a sound driver for Media Vision's Pro Audio Spectrum
  1268.       sound boards
  1269. Note:    the installation check consists of testing for the signature string
  1270.       "PCMDRIVER" immediately preceding the interrupt handler; the word
  1271.       preceding the signature gives the PCM driver's version
  1272. SeeAlso: SI=0001h,SI=0002h,SI=0003h,SI=0004h,SI=0005h,SI=000Ah
  1273. Index:    installation check;PCM driver|PCM.COM;installation check
  1274. Index:    PCM driver;installation check
  1275. --------s-94----SI0001-----------------------
  1276. INT 94 u - PCM driver - INITIALIZE PCM
  1277.     SI = 0001h
  1278.     ES:BX -> parameters
  1279. Return: ???
  1280. SeeAlso: SI=0000h,SI=0002h,SI=0003h,SI=000Ah
  1281. --------s-94----SI0002-----------------------
  1282. INT 94 u - PCM driver - INITIALIZE PCM INFO
  1283.     SI = 0002h
  1284.     ES:BX -> parameters (see #3246)
  1285. Return: ???
  1286. SeeAlso: SI=0000h,SI=0001h,SI=0003h,SI=000Ah
  1287.  
  1288. Format of PCM driver function 0002h parameters:
  1289. Offset    Size    Description    (Table 3246)
  1290.  00h    DWORD    rate
  1291.  04h    WORD    channel number
  1292.  06h    WORD    "comp"
  1293.  08h    WORD    "dsize"
  1294. --------s-94----SI0003-----------------------
  1295. INT 94 u - PCM driver - INITIALIZE DMA BUFFER
  1296.     SI = 0003h
  1297.     ES:BX -> parameters (see #3247)
  1298. Return: ???
  1299. SeeAlso: SI=0000h,SI=000Ah,SI=000Bh
  1300.  
  1301. Format of PCM driver function 0003h parameters:
  1302. Offset    Size    Description    (Table 3247)
  1303.  00h    DWORD    -> DMA buffer
  1304.  04h    WORD    size of DMA buffer
  1305.  06h    WORD    number of divisions
  1306. --------s-94----SI0004-----------------------
  1307. INT 94 u - PCM driver - INITIALIZE USER FUNCTION
  1308.     SI = 0004h
  1309.     ES:BX -> parameters (see #3248)
  1310. Return: ???
  1311. SeeAlso: SI=0000h,SI=0001h
  1312.  
  1313. Format of PCM driver function 0004h parameters:
  1314. Offset    Size    Description    (Table 3248)
  1315.  00h    DWORD    -> user function
  1316. --------s-94----SI0005-----------------------
  1317. INT 94 u - PCM driver - BEGIN AUDIO PLAY
  1318.     SI = 0005h
  1319. Return: ???
  1320. SeeAlso: SI=0000h,SI=0006h,SI=0007h,SI=0009h
  1321. --------s-94----SI0006-----------------------
  1322. INT 94 u - PCM driver - BEGIN AUDIO RECORD
  1323.     SI = 0006h
  1324. Return: ???
  1325. SeeAlso: SI=0005h,SI=0007h,SI=0009h
  1326. --------s-94----SI0007-----------------------
  1327. INT 94 u - PCM driver - PAUSE AUDIO PLAY/RECORD
  1328.     SI = 0007h
  1329. Return: ???
  1330. SeeAlso: SI=0005h,SI=0006h,SI=0008h
  1331. --------s-94----SI0008-----------------------
  1332. INT 94 u - PCM driver - RESUME AUDIO PLAY/RECORD
  1333.     SI = 0008h
  1334. Return: ???
  1335. SeeAlso: SI=0007h
  1336. --------s-94----SI0009-----------------------
  1337. INT 94 u - PCM driver - STOP AUDIO PLAY/RECORD
  1338.     SI = 0009h
  1339. Return: ???
  1340. SeeAlso: SI=0005h,SI=0006h,SI=0007h
  1341. --------s-94----SI000A-----------------------
  1342. INT 94 u - PCM driver - UNHOOK INTERRUPTS AND TURN OFF DMA
  1343.     SI = 000Ah
  1344. Return: ???
  1345. SeeAlso: SI=0000h,SI=0001h,SI=0003h
  1346. Index:    uninstall;PCM driver
  1347. --------s-94----SI000B-----------------------
  1348. INT 94 u - PCM driver - FIND VALID DMA BUFFER IN HUGE MEMORY BLOCK
  1349.     SI = 000Bh
  1350.     ES:BX -> parameters (see #3249)
  1351. Return: ???
  1352. SeeAlso: SI=0003h
  1353.  
  1354. Format of PCM driver functio 000Bh parameters:
  1355. Offset    Size    Description    (Table 3249)
  1356.  00h    DWORD    -> memory block to contain DMA buffer
  1357.  04h    WORD    desired size of DMA buffer
  1358. --------s-94----SI000D-----------------------
  1359. INT 94 u - Media Vision PCM.COM - GET STATUS
  1360.     SI = 000Dh
  1361. Return: AX = status (0000h = waiting) (see #3250)
  1362.  
  1363. Bitfields for PCM.COM status:
  1364. Bit(s)    Description    (Table 3250)
  1365.  0    playing
  1366.  1    recording
  1367.  2    SBplaying
  1368.  3    SBrecording
  1369.  14    SBpaused
  1370.  15    paused
  1371. --------s-94----SI8000-----------------------
  1372. INT 94 u - Media Vision PCM.COM - GET INTERNAL DMA BUFFER ADDRESS
  1373.     SI = 8000h
  1374. Return: DX:AX -> DMA buffer
  1375. Program: PCM.COM is a superset of the standard PCM driver which provides
  1376.       additional functions for fine control of the driver
  1377. Note:    the installation check for the Media Vision PCM.COM "shark" functions
  1378.       consists of testing for the signature "PCM-SHARK" at offset 107h in
  1379.       the INT 94 handler's segment
  1380. SeeAlso: SI=8001h,SI=8004h
  1381. Index:    installation check;Media Vision PCM.COM|PCM.COM;installation check
  1382. Index:    Media Vision PCM.COM;"shark" functions
  1383. --------s-94----SI8001-----------------------
  1384. INT 94 u - Media Vision PCM.COM - GET INTERNAL DMA BUFFER SIZE AND DIVISIONS
  1385.     SI = 8001h
  1386. Return: AX = DMA buffer size
  1387.     DX = divisions
  1388. SeeAlso: SI=8000h
  1389. --------s-94----SI8002-----------------------
  1390. INT 94 u - Media Vision PCM.COM - CHECK BOARD ADDRESS
  1391.     SI = 8002h
  1392. Return: AX = status
  1393.         0000h if board not at specified I/O address
  1394.         other if board found
  1395. Note:    the I/O address is specified by ORing the base I/O port shifted left
  1396.       four bits into SI before calling INT 94
  1397. SeeAlso: SI=8000h
  1398. --------s-94----SI8004-----------------------
  1399. INT 94 u - Media Vision PCM.COM - GET INTERNAL NOTE BUFFER
  1400.     SI = 8004h
  1401. Return: AX = offset of note buffer (segment = segment of internal DMA buffer)
  1402.     DX = size of buffer in note structures
  1403. SeeAlso: SI=8000h
  1404. --------s-94----SI8005-----------------------
  1405. INT 94 u - Media Vision PCM.COM - SINGLE-STEP QUEUE
  1406.     SI = 8005h
  1407. Return: ???
  1408. --------s-94----SI8011-----------------------
  1409. INT 94 u - Media Vision PCM.COM - INITIALIZE
  1410.     SI = 8011h
  1411.     ES:BX -> "iobf91" structure
  1412. Return: ???
  1413. --------s-94----SI8012-----------------------
  1414. INT 94 u - Media Vision PCM.COM - LOAD SOUND FOR LATER PLAY THROUGH KEYBOARD
  1415.     SI = 8012h
  1416.     ES:BX -> "i94f92buf" structure
  1417. Return: ???
  1418. SeeAlso: SI=8013h,SI=8014h
  1419. --------s-94----SI8013-----------------------
  1420. INT 94 u - Media Vision PCM.COM - GET INTERNAL SOUND USAGE
  1421.     SI = 8013h
  1422. Return: AX = number of sounds used
  1423.     DX = maximum handles
  1424. --------s-94----SI8014-----------------------
  1425. INT 94 u - Media Vision PCM.COM - GET DATA FOR SPECIFIED SOUND
  1426.     SI = 8014h
  1427.     ES:BX -> "i94f92buf" structure to be filled in
  1428.         sound number field set to desired sound
  1429. Return: AX = status
  1430.         0000h successful
  1431.         FFFFh sound number out of range
  1432. SeeAlso: SI=8012h,SI=8013h
  1433. --------s-94----SI8015-----------------------
  1434. INT 94 u - Media Vision PCM.COM - GET/SET INTERNAL DMA BUFFER
  1435.     SI = 8015h
  1436.     ES:BX -> DMA info structure (see #3251)
  1437. Return: ???
  1438.  
  1439. Format of PCM.COM DMA info structure:
  1440. Offset    Size    Description    (Table 3251)
  1441.  00h    DWORD    -> DMA buffer (offset FFFFh = return current buffer info)
  1442.  04h    WORD    DMA buffer size
  1443.  06h    WORD    divisions
  1444. --------s-94----SI8016-----------------------
  1445. INT 94 u - Media Vision PCM.COM - SIMULATE DOUBLE-SHIFT HOTKEY
  1446.     SI = 8016h
  1447.     AX = hotkey number (01h-08h)
  1448. Return: ???
  1449. SeeAlso: AL=02h/SI=8017h
  1450. --------s-94--01SI8017-----------------------
  1451. INT 94 u - Media Vision PCM.COM - CTRL-G INTERCEPT
  1452.     AL = 01h
  1453.     SI = 8017h
  1454.     AH = new state (00h off, 01h on)
  1455. Return: ???
  1456. SeeAlso: AL=02h/SI=8017h
  1457. --------s-94--02SI8017-----------------------
  1458. INT 94 u - Media Vision PCM.COM - DOUBLE-SHIFT-HOTKEY SOUND FEATURE
  1459.     AL = 02h
  1460.     SI = 8017h
  1461.     AH = new state (00h off, 01h on)
  1462. Return: ???
  1463. --------s-94--04SI8017-----------------------
  1464. INT 94 u - Media Vision PCM.COM - RANDOM SOUND FEATURE
  1465.     AL = 04h
  1466.     SI = 8017h
  1467.     AH = new state
  1468.         00h off
  1469.         01h on
  1470.         CX = minimum delay
  1471.         DX = maximum delay
  1472. Return: ???
  1473. --------s-94--08SI8017-----------------------
  1474. INT 94 u - Media Vision PCM.COM - NO ACTIVITY FEATURE
  1475.     AL = 08h
  1476.     SI = 8017h
  1477.     AH = new state
  1478.         00h off
  1479.         01h on
  1480.         DX:CX = delay
  1481. Return: ???
  1482. SeeAlso: AL=10h/SI=8017h
  1483. --------s-94--10SI8017-----------------------
  1484. INT 94 u - Media Vision PCM.COM - TIMER CONTROL
  1485.     AL = 10h
  1486.     SI = 8017h
  1487.     AH = timer options (see #3252)
  1488.     DX:CX = delay if AH bit 7 set (one-shot if DX bit 15 set)
  1489. Return: ???
  1490. SeeAlso: AL=08h/SI=8017h
  1491.  
  1492. Bitfields for PCM.COM timer options:
  1493. Bit(s)    Description    (Table 3252)
  1494.  7    set timer
  1495.  6    timer active (timer turned off if clear)
  1496.  5-0    timer number
  1497. --------s-94----SI8018-----------------------
  1498. INT 94 u - Media Vision PCM.COM - GET INFO
  1499.     SI = 8018h
  1500.     AL = what to get
  1501.         00h "F92state"
  1502.         01h "F92bkgd"
  1503.         02h "I10timer"
  1504.         03h "I08state"
  1505. Return: DX:AX -> desired information
  1506. --------r-95---------------------------------
  1507. INT 95 - IBM ROM BASIC - used while in interpreter
  1508. Notes:    called by ROM BASIC
  1509.     BASIC.COM/BASICA.COM do not restore vector on termination
  1510. --------r-95---------------------------------
  1511. INT 95 - APL*PLUS/PC - DETERMINE R= SPACE
  1512. Note:    use only when the R= option is invoked on entering APL
  1513. --------r-96---------------------------------
  1514. INT 96 - IBM ROM BASIC - used while in interpreter
  1515. Notes:    called by ROM BASIC
  1516.     BASIC.COM/BASICA.COM do not restore vector on termination
  1517. --------U-96---------------------------------
  1518. INT 96 U - KILL.COM, QKILL.COM - POP UP
  1519. Program: KILL.COM is a TSR utility that allows you to terminate programs
  1520.      by calling INT 21/AH=4Ch or reboot the computer (author unknown);
  1521.      QKILL.COM is a modification of KILL.COM by Solar Designer that
  1522.      supports QEMM's Quick Boot feature
  1523. Notes:    This interrupt is intercepted but not chained by KILL.COM; it is never
  1524.       called by KILL.COM itself. It points into the middle of KILL.COM's
  1525.       INT 09 handler and assumes specific values have been placed on the
  1526.       stack (thus it can't be called as an interrupt).
  1527.     To invoke KILL, use the following code:
  1528.         pushf
  1529.         push cs
  1530.         push offset $+0Dh
  1531.         push ax
  1532.         push es
  1533.         push 0
  1534.         pop  es
  1535.         jmp  dword ptr es:[96h*4]
  1536. --------r-97---------------------------------
  1537. INT 97 - IBM ROM BASIC - used while in interpreter
  1538. Notes:    called by ROM BASIC
  1539.     BASIC.COM/BASICA.COM do not restore vector on termination
  1540. --------r-98---------------------------------
  1541. INT 98 - IBM ROM BASIC - used while in interpreter
  1542. Notes:    called by ROM BASIC, but pointed at IRET by BASIC.COM/BASICA.COM
  1543.     BASIC.COM/BASICA.COM do not restore vector on termination
  1544. --------r-99---------------------------------
  1545. INT 99 - IBM ROM BASIC - used while in interpreter
  1546. Notes:    called by ROM BASIC, but pointed at IRET by BASIC.COM/BASICA.COM
  1547.     BASIC.COM/BASICA.COM do not restore vector on termination
  1548. --------r-9A---------------------------------
  1549. INT 9A - IBM ROM BASIC - used while in interpreter
  1550. Notes:    called by ROM BASIC, but pointed at IRET by BASIC.COM/BASICA.COM
  1551.     BASIC.COM/BASICA.COM do not restore vector on termination
  1552. SeeAlso: INT 80"BASIC",INT 99,INT 9B
  1553. --------r-9B---------------------------------
  1554. INT 9B - IBM ROM BASIC - used while in interpreter
  1555. Notes:    called by ROM BASIC, but pointed at IRET by BASIC.COM/BASICA.COM
  1556.     BASIC.COM/BASICA.COM do not restore vector on termination
  1557. SeeAlso: INT 80"BASIC",INT 9A,INT 9C"BASIC"
  1558. --------r-9C---------------------------------
  1559. INT 9C - IBM ROM BASIC - used while in interpreter
  1560. Notes:    called by ROM BASIC, but pointed at IRET by BASIC.COM/BASICA.COM
  1561.     BASIC.COM/BASICA.COM do not restore vector on termination
  1562. SeeAlso: INT 80"BASIC",INT 9B,INT 9D"BASIC"
  1563. --------v-9C---------------------------------
  1564. INT 9C - VIRUS - "INT13" - ORIGINAL INT 13h VECTOR
  1565. SeeAlso: INT 8B"VIRUS",INT 9D"VIRUS",INT 9E"VIRUS",INT 9F"VIRUS"
  1566. --------r-9D---------------------------------
  1567. INT 9D - IBM ROM BASIC - used while in interpreter
  1568. Notes:    called by ROM BASIC, but pointed at IRET by BASIC.COM/BASICA.COM
  1569.     BASIC.COM/BASICA.COM do not restore vector on termination
  1570. SeeAlso: INT 80"BASIC",INT 9C"BASIC",INT 9E"BASIC"
  1571. --------v-9D---------------------------------
  1572. INT 9D - VIRUS - "INT13" - ROM INT 13h ENTRY POINT
  1573. Note:    this vector is used by the virus to store the result of a call to
  1574.       INT 2F/AH=13h
  1575. SeeAlso: INT 2F/AH=13h,INT 9C"VIRUS",INT 9E"VIRUS",INT 9F"VIRUS"
  1576. --------r-9E---------------------------------
  1577. INT 9E - IBM ROM BASIC - used while in interpreter
  1578. Notes:    called by ROM BASIC, but pointed at IRET by BASIC.COM/BASICA.COM
  1579.     BASIC.COM/BASICA.COM do not restore vector on termination
  1580. SeeAlso: INT 80"BASIC",INT 9D"BASIC",INT 9F"BASIC"
  1581. --------v-9E---------------------------------
  1582. INT 9E - VIRUS - "INT13" - ORIGINAL INT 21h VECTOR
  1583. SeeAlso: INT 70"VIRUS",INT 9C"VIRUS",INT 9D"VIRUS",INT E0"VIRUS"
  1584. --------r-9F---------------------------------
  1585. INT 9F - IBM ROM BASIC - used while in interpreter
  1586. Notes:    called by ROM BASIC
  1587.     BASIC.COM/BASICA.COM do not restore vector on termination
  1588. SeeAlso: INT 80"BASIC",INT 9D"BASIC",INT A0"BASIC"
  1589. --------v-9F---------------------------------
  1590. INT 9F - VIRUS - "INT13" - STORAGE FOR USER INT 13h VECTOR
  1591. Note:    while it is infecting a file, the INT13 virus grabs INT 13 and uses
  1592.       this interrupt to store the existing INT 13 vector for later
  1593.       restoration
  1594. SeeAlso: INT 9C"VIRUS",INT 9D"VIRUS",INT D3"VIRUS"
  1595. --------r-A0---------------------------------
  1596. INT A0 - IBM ROM BASIC - used while in interpreter
  1597. Notes:    called by ROM BASIC
  1598.     BASIC.COM/BASICA.COM do not restore vector on termination
  1599. SeeAlso: INT 80"BASIC",INT 9F"BASIC",INT A1"BASIC"
  1600. --------r-A0---------------------------------
  1601. INT A0 - APL*PLUS/PC - USED BY APL/GSS*CGI GRAPHICS INTERFACE
  1602. SeeAlso: INT 59
  1603. --------r-A1---------------------------------
  1604. INT A1 - IBM ROM BASIC - used while in interpreter
  1605. Notes:    called by ROM BASIC, but pointed at IRET by BASIC.COM/BASICA.COM
  1606.     BASIC.COM/BASICA.COM do not restore vector on termination
  1607. SeeAlso: INT 80"BASIC",INT A0"BASIC",INT A2"BASIC"
  1608. --------r-A2---------------------------------
  1609. INT A2 - IBM ROM BASIC - used while in interpreter
  1610. Notes:    called by ROM BASIC
  1611.     BASIC.COM/BASICA.COM do not restore vector on termination
  1612. SeeAlso: INT 80"BASIC",INT A1"BASIC",INT A3"BASIC"
  1613. --------r-A3---------------------------------
  1614. INT A3 - IBM ROM BASIC - used while in interpreter
  1615. Notes:    called by ROM BASIC
  1616.     BASIC.COM/BASICA.COM do not restore vector on termination
  1617. SeeAlso: INT 80"BASIC",INT A2"BASIC",INT A4"BASIC"
  1618. --------r-A4---------------------------------
  1619. INT A4 - IBM ROM BASIC - used while in interpreter
  1620. Notes:    called by ROM BASIC, but pointed at IRET by BASIC.COM/BASICA.COM
  1621.     BASIC.COM/BASICA.COM do not restore vector on termination
  1622. SeeAlso: INT 80"BASIC",INT A3"BASIC",INT A5"BASIC"
  1623. --------U-A4---------------------------------
  1624. INT A4 U - Right Hand Man - API
  1625.     AH = function number (v3.3 supports functions 00h-52h)
  1626. Return: CF set on error
  1627.     CF clear if successful
  1628. Program: Right Hand Man is a TSR desk-top utility originally by Red E Products
  1629.       which has evolved into Futurus Team
  1630. Note:    this interrupt is only hooked while popped up
  1631. SeeAlso: INT 2F/AX=A4E0h
  1632. --------r-A5---------------------------------
  1633. INT A5 - IBM ROM BASIC - used while in interpreter
  1634. Notes:    called by ROM BASIC, but pointed at IRET by BASIC.COM/BASICA.COM
  1635.     BASIC.COM/BASICA.COM do not restore vector on termination
  1636. SeeAlso: INT 80"BASIC",INT A4"BASIC",INT A6"BASIC"
  1637. --------r-A6---------------------------------
  1638. INT A6 - IBM ROM BASIC - used while in interpreter
  1639. Notes:    called by ROM BASIC
  1640.     BASIC.COM/BASICA.COM do not restore vector on termination
  1641. SeeAlso: INT 80"BASIC",INT A5"BASIC",INT A7"BASIC"
  1642. --------r-A7---------------------------------
  1643. INT A7 - IBM ROM BASIC - used while in interpreter
  1644. Notes:    called by ROM BASIC
  1645.     BASIC.COM/BASICA.COM do not restore vector on termination
  1646. --------r-A8---------------------------------
  1647. INT A8 - IBM ROM BASIC - used while in interpreter
  1648. Notes:    called by ROM BASIC
  1649.     BASIC.COM/BASICA.COM do not restore vector on termination
  1650. --------r-A9---------------------------------
  1651. INT A9 - IBM ROM BASIC - used while in interpreter
  1652. Notes:    called by ROM BASIC
  1653.     BASIC.COM/BASICA.COM do not restore vector on termination
  1654. --------r-AA---------------------------------
  1655. INT AA - IBM ROM BASIC - used while in interpreter
  1656. Notes:    called by ROM BASIC, but pointed at IRET by BASIC.COM/BASICA.COM
  1657.     BASIC.COM/BASICA.COM do not restore vector on termination
  1658. --------r-AB---------------------------------
  1659. INT AB - IBM ROM BASIC - used while in interpreter
  1660. Notes:    called by ROM BASIC
  1661.     BASIC.COM/BASICA.COM do not restore vector on termination
  1662. --------r-AC---------------------------------
  1663. INT AC - IBM ROM BASIC - used while in interpreter
  1664. Notes:    called by ROM BASIC
  1665.     BASIC.COM/BASICA.COM do not restore vector on termination
  1666. --------r-AD---------------------------------
  1667. INT AD - IBM ROM BASIC - used while in interpreter
  1668. Notes:    called by ROM BASIC
  1669.     BASIC.COM/BASICA.COM do not restore vector on termination
  1670. --------r-AE---------------------------------
  1671. INT AE - IBM ROM BASIC - used while in interpreter
  1672. Notes:    called by ROM BASIC, but pointed at IRET by BASIC.COM/BASICA.COM
  1673.     BASIC.COM/BASICA.COM do not restore vector on termination
  1674. --------r-AF---------------------------------
  1675. INT AF - IBM ROM BASIC - used while in interpreter
  1676. Notes:    called by ROM BASIC
  1677.     BASIC.COM/BASICA.COM do not restore vector on termination
  1678. --------r-B0---------------------------------
  1679. INT B0 - IBM ROM BASIC - used while in interpreter
  1680. Notes:    called by ROM BASIC, but pointed at IRET by BASIC.COM/BASICA.COM
  1681.     BASIC.COM/BASICA.COM do not restore vector on termination
  1682. --------r-B1---------------------------------
  1683. INT B1 - IBM ROM BASIC - used while in interpreter
  1684. Notes:    called by ROM BASIC, but pointed at IRET by BASIC.COM/BASICA.COM
  1685.     BASIC.COM/BASICA.COM do not restore vector on termination
  1686. --------r-B2---------------------------------
  1687. INT B2 - IBM ROM BASIC - used while in interpreter
  1688. Notes:    called by ROM BASIC
  1689.     BASIC.COM/BASICA.COM do not restore vector on termination
  1690. --------r-B3---------------------------------
  1691. INT B3 - IBM ROM BASIC - used while in interpreter
  1692. Notes:    called by ROM BASIC, but pointed at IRET by BASIC.COM/BASICA.COM
  1693.     BASIC.COM/BASICA.COM do not restore vector on termination
  1694. --------U-B370-------------------------------
  1695. INT B3 - ZIPKEY - GET VERSION
  1696.     AH = 70h
  1697. Return: AH = major version
  1698.     AL = minor version
  1699.     CL = number of states and territories in current database
  1700.     DH = year of current database - 1900
  1701.     DL = month of current database's file date
  1702. Program: ZIPKEY is a resident ZIPCODE database by Eric Isaacson
  1703. Note:    if installed, the string "ZIPKEY" is present at offset 75h in the
  1704.       interrupt handler's segment, and the byte at 7Bh contains the API
  1705.       version number (00h for v1.x, 01h for v2.0)
  1706. --------U-B371-------------------------------
  1707. INT B3 - ZIPKEY - CONVERT TWO-LETTER ABBREVIATION TO STATE CODE
  1708.     AH = 71h
  1709.     BX = abbreviation, in either case (first letter in BL)
  1710. Return: CF set on error
  1711.         AL = FFh
  1712.     CF clear if successful
  1713.         AL = ZIPKEY state code
  1714. SeeAlso: AH=72h
  1715. --------U-B372-------------------------------
  1716. INT B3 - ZIPKEY - CONVERT STATE CODE TO TWO-LETTER ABBREVIATION
  1717.     AH = 72h
  1718.     BL = ZIPKEY state code
  1719. Return: CF set on error
  1720.         AX destroyed
  1721.     CF clear if successful
  1722.         AX = abbreviation, in upper case
  1723. SeeAlso: AH=71h,AH=73h
  1724. --------U-B373-------------------------------
  1725. INT B3 - ZIPKEY - CONVERT STATE CODE TO STATE NAME
  1726.     AH = 73h
  1727.     BL = ZIPKEY state code
  1728.     ES:DI -> buffer for name
  1729. Return: CF set on error
  1730.         AX destroyed
  1731.     CF clear if successful
  1732.         ES:DI points one byte beyond end of name
  1733. SeeAlso: AH=72h
  1734. --------U-B374-------------------------------
  1735. INT B3 - ZIPKEY - CONVERT ZIPCODE TO ASCII DIGITS
  1736.     AH = 74h
  1737.     DX = zipcode region (0-999)
  1738.     CH = last two digits of zipcode (0-99)
  1739.     ES:DI -> buffer
  1740. Return: CF set on error
  1741.         AX destroyed
  1742.     CF clear if successful
  1743.         ES:DI points one byte beyond end of digit string
  1744. --------U-B375-------------------------------
  1745. INT B3 - ZIPKEY - LOOK UP STATE CODE FOR ZIPCODE
  1746.     AH = 75h
  1747.     DX = zipcode region (0-999)
  1748.     CH = last two digits of zipcode (0-99)
  1749. Return: CF set on error (zipcode not found)
  1750.         AL = suggested state code, FFh if none
  1751.     CF clear if successful
  1752.         AL = ZIPKEY state code
  1753.         BX = area code (v2.0+)
  1754. SeeAlso: AH=76h,AH=79h
  1755. --------U-B376-------------------------------
  1756. INT B3 - ZIPKEY - LOOK UP CITY AND STATE FOR ZIPCODE
  1757.     AH = 76h
  1758.     DX = zipcode region (0-999)
  1759.     CH = last two digits of zipcode (0-99)
  1760.     ES:DI -> buffer for name
  1761. Return: CF set on error
  1762.         AL = suggested state code, FFh if none
  1763.         ES:DI buffer filled with suggested city name
  1764.     CF clear if successful
  1765.         AL = ZIPKEY state code
  1766.         BX = area code (v2.0+)
  1767.         ES:DI points one byte beyond end of name
  1768. SeeAlso: AH=75h,AH=78h,AH=7Eh
  1769. --------U-B377-------------------------------
  1770. INT B3 - ZIPKEY - PLAY BACK EXIT KEY FOR ENTRY WITH GIVEN ZIPCODE
  1771.     AH = 77h
  1772.     DX = zipcode region (0-999)
  1773.     CH = last two digits of zipcode (0-99)
  1774.     BX = 16-bit BIOS keycode for a defined ZIPKEY alternate exit key
  1775. Return: CF set on error
  1776.         AX destroyed
  1777.     CF clear if successful
  1778.         zipcode specification as defined by the BX keystroke is placed in
  1779.           keyboard buffer, as if the user had popped up ZIPKEY and exited
  1780.           by pressing the key specified by BX
  1781. --------U-B378-------------------------------
  1782. INT B3 - ZIPKEY - LOOK UP ZIPCODES FOR A GIVEN STATE AND CITY
  1783.     AH = 78h
  1784.     BL = ZIPKEY state code
  1785.     DS:SI -> city name, terminated with 0Dh if complete name, 00h if prefix
  1786. Return: BH = number of matching entries (set to 51 if more than 50)
  1787.     DX = zipcode region of first match (0-999)
  1788.     CL = last two digits of first zipcode in the range (0-99)
  1789.     CH = last two digits of last zipcode in the range (0-99)
  1790.     AX destroyed
  1791. SeeAlso: AH=79h,AH=7Ah
  1792. --------U-B379-------------------------------
  1793. INT B3 - ZIPKEY - LOOK UP ZIPCODES FOR A GIVEN CITY
  1794.     AH = 79h
  1795.     BL = ZIPKEY state code of first state to search
  1796.     DS:SI -> city name, terminated with 0Dh if complete name, 00h if prefix
  1797. Return: AL = ZIPKEY state code of first matching state
  1798.     BH = number of matching entries (set to 51 if more than 50)
  1799.     DX = zipcode region of first match (0-999)
  1800.     CL = last two digits of first zipcode in first range (0-99)
  1801.     CH = last two digits of last zipcode in first range (0-99)
  1802. Note:    to find all matching cities, repeat search with BL set to one more than
  1803.       the returned AL
  1804. SeeAlso: AH=78h,AH=7Ah
  1805. --------U-B37A-------------------------------
  1806. INT B3 - ZIPKEY - FETCH AN ENTRY FROM A PREVIOUS LOOKUP
  1807.     AH = 7Ah
  1808.     BL = case number (0 to one less than value returned in BH by lookup)
  1809. Return: AL = ZIPKEY state code
  1810.     DX = zipcode region (0-999)
  1811.     CL = last two digits of first zipcode in the range (0-99)
  1812.     CH = last two digits of last zipcode in the range (0-99)
  1813. SeeAlso: AH=78h,AH=79h
  1814. --------U-B37B-------------------------------
  1815. INT B3 - ZIPKEY - GET VALUES NEEDED TO SAVE ZIPKEY CONTEXT
  1816.     AH = 7Bh
  1817. Return: BL = maximum number of characters for a city name
  1818.     BH = ZIPKEY state code for last city-name search, or FFh if none
  1819.     CX:DX = internal code identifying last city search
  1820.     AX destroyed
  1821. SeeAlso: AH=7Ch
  1822. --------U-B37C-------------------------------
  1823. INT B3 - ZIPKEY - RESTORE ZIPKEY CONTEXT
  1824.     AH = 7Ch
  1825.     BL = maximum number of characters for a city name
  1826.     BH = ZIPKEY state code for last city-name search, or FFh if none
  1827.     CX:DX = internal code returned by AH=7Bh
  1828. Return: CF set on error
  1829.     CF clear if successful
  1830.     AX destroyed
  1831. SeeAlso: AH=7Bh
  1832. --------U-B37D-------------------------------
  1833. INT B3 - ZIPKEY - REQUEST POP UP
  1834.     AH = 7Dh
  1835.     BL = index number to simulate pressing a hotkey
  1836.         FFh for immediate popup with no playback on return
  1837. Return: CF set on error
  1838.         AL = error code
  1839.         FDh already busy with another request
  1840.         FEh illegal function
  1841.     CF clear if successful
  1842.         AX destroyed
  1843.         window popped up and was closed by the user
  1844. SeeAlso: AH=70h
  1845. --------U-B37E-------------------------------
  1846. INT B3 - ZIPKEY - GET NAME OF PRIMARY CITY FOR A ZIPCODE REGION
  1847.     AH = 7Eh
  1848.     DX = zipcode region (0-999)
  1849.     ES:DI -> buffer for name
  1850. Return: CF set on error
  1851.         AL = FFh region does not exist
  1852.     CF clear if successful
  1853.         AL = ZIPKEY state code
  1854.         ES:DI points one byte beyond end of name
  1855. SeeAlso: AH=76h
  1856. --------U-B37F-------------------------------
  1857. INT B3 - ZIPKEY - ENABLE/DISABLE HOTKEYS
  1858.     AH = 7Fh
  1859.     BL = function
  1860.         00h turn off hotkeys
  1861.         01h turn on hotkeys
  1862.         02h return hotkey status
  1863.         03h toggle hotkey status
  1864. Return: AL = hotkey status
  1865.         00h off
  1866.         01h on
  1867. --------U-B380-------------------------------
  1868. INT B3 - ZIPKEY v2.0+ - DETERMINE STATE FOR AREA CODE
  1869.     AH = 80h
  1870.     BX = telephone area code (decimal)
  1871. Return: CF clear if successful
  1872.         AL = ZIPKEY state code
  1873.         DX = first ZIP region for state (03E8h if Canada)
  1874.         CX = number of ZIP regions in state
  1875.     CF set on error
  1876.         AL = FFh
  1877.         DX = 03E9h
  1878. --------r-B4---------------------------------
  1879. INT B4 - IBM ROM BASIC - used while in interpreter
  1880. Notes:    called by ROM BASIC
  1881.     BASIC.COM/BASICA.COM do not restore vector on termination
  1882. --------r-B4---------------------------------
  1883. INT B4 - StackMan - REQUEST NEW STACK
  1884. Return: SS:SP -> new stack
  1885. Program: StackMan is a freeware stack manager by Franz Veldman of ESaSS B.V.
  1886.       which functions as a replacement for the DOS STACK= command as well
  1887.       as permitting multiple TSRs to share a pool of stack space
  1888. Note:    the installation check consists of testing for the string "STACKXXX" at
  1889.       offset 0Ah from the interrupt handler
  1890. SeeAlso: INT 2F/AX=C9FFh,INT B5"STACKMAN"
  1891. Index:    installation check;STACKMAN
  1892. --------r-B5---------------------------------
  1893. INT B5 - IBM ROM BASIC - used while in interpreter
  1894. Notes:    called by ROM BASIC, but pointed at IRET by BASIC.COM/BASICA.COM
  1895.     BASIC.COM/BASICA.COM do not restore vector on termination
  1896. SeeAlso: INT 80"BASIC",INT B4"BASIC",INT B6"BASIC"
  1897. --------r-B5---------------------------------
  1898. INT B5 - StackMan - RESTORE ORIGINAL STACK
  1899.     SS:SP -> stack returned by INT B4
  1900. Return: SS:SP restored to value before INT B4
  1901. SeeAlso: INT 2F/AX=C9FFh,INT B4"StackMan"
  1902. --------m-B5---------------------------------
  1903. INT B5 U - Netroom NETSWAP4 - ???
  1904.     ???
  1905. Return: ???
  1906. SeeAlso: INT 31/AH=57h
  1907. --------r-B6---------------------------------
  1908. INT B6 - IBM ROM BASIC - used while in interpreter
  1909. Notes:    called by ROM BASIC
  1910.     BASIC.COM/BASICA.COM do not restore vector on termination
  1911. SeeAlso: INT 80"BASIC",INT B5"BASIC",INT B7"BASIC"
  1912. --------y-B6---------------------------------
  1913. INT B6 - (NOT A VECTOR!) - USED BY TBFENCE
  1914. Program: TBFence is a security program by ESaSS B.V. which transparently
  1915.       encrypts floppies and optionally allows only encrypted diskettes to
  1916.       be accessed
  1917. Note:    the low word of this vector (0000h:02D8h) contains the segment of the
  1918.       TBFence INT 13h code, which starts with the signature word E487h;
  1919.       this forms the installation check
  1920.     the highest byte of this vector contains the start of a FAR JMP
  1921.       instruction to ???
  1922. SeeAlso: INT B7"TBFENCE"
  1923. Index:    installation check;TBFence
  1924. --------r-B7---------------------------------
  1925. INT B7 - IBM ROM BASIC - used while in interpreter
  1926. Notes:    called by ROM BASIC, but pointed at IRET by BASIC.COM/BASICA.COM
  1927.     BASIC.COM/BASICA.COM do not restore vector on termination
  1928. SeeAlso: INT 80"BASIC",INT B6"BASIC",INT B8"BASIC"
  1929. --------y-B7---------------------------------
  1930. INT B7 - TBFENCE - ???
  1931. SeeAlso: INT B6"TBFENCE"
  1932. --------r-B8---------------------------------
  1933. INT B8 - IBM ROM BASIC - used while in interpreter
  1934. Notes:    called by ROM BASIC
  1935.     BASIC.COM/BASICA.COM do not restore vector on termination
  1936. SeeAlso: INT 80"BASIC",INT B7"BASIC",INT B9"BASIC"
  1937. --------r-B9---------------------------------
  1938. INT B9 - IBM ROM BASIC - used while in interpreter
  1939. Notes:    called by ROM BASIC, but pointed at IRET by BASIC.COM/BASICA.COM
  1940.     BASIC.COM/BASICA.COM do not restore vector on termination
  1941. --------r-BA---------------------------------
  1942. INT BA - IBM ROM BASIC - used while in interpreter
  1943. Notes:    called by ROM BASIC, but pointed at IRET by BASIC.COM/BASICA.COM
  1944.     BASIC.COM/BASICA.COM do not restore vector on termination
  1945. --------r-BB---------------------------------
  1946. INT BB - IBM ROM BASIC - used while in interpreter
  1947. Notes:    called by ROM BASIC, but pointed at IRET by BASIC.COM/BASICA.COM
  1948.     BASIC.COM/BASICA.COM do not restore vector on termination
  1949. --------r-BC---------------------------------
  1950. INT BC - IBM ROM BASIC - used while in interpreter
  1951. Notes:    called by ROM BASIC, but pointed at IRET by BASIC.COM/BASICA.COM
  1952.     BASIC.COM/BASICA.COM do not restore vector on termination
  1953. --------r-BD---------------------------------
  1954. INT BD - IBM ROM BASIC - used while in interpreter
  1955. Notes:    called by ROM BASIC, but pointed at IRET by BASIC.COM/BASICA.COM
  1956.     BASIC.COM/BASICA.COM do not restore vector on termination
  1957. --------r-BE---------------------------------
  1958. INT BE - IBM ROM BASIC - used while in interpreter
  1959. Notes:    called by ROM BASIC, but pointed at IRET by BASIC.COM/BASICA.COM
  1960.     BASIC.COM/BASICA.COM do not restore vector on termination
  1961. SeeAlso: INT 80"BASIC",INT BD"BASIC",INT BF"BASIC"
  1962. --------Q-BE---------------------------------
  1963. INT BE - DESQview/X - ???
  1964. Note:    points at an IRET
  1965. SeeAlso: INT 15/AX=BFDEh/BX=0006h,INT 63"DESQview"
  1966. --------r-BF---------------------------------
  1967. INT BF - IBM ROM BASIC - used while in interpreter
  1968. Notes:    called by ROM BASIC, but pointed at IRET by BASIC.COM/BASICA.COM
  1969.     BASIC.COM/BASICA.COM do not restore vector on termination
  1970. SeeAlso: INT 80"BASIC",INT BE"BASIC",INT C0"BASIC"
  1971. --------r-C0---------------------------------
  1972. INT C0 - IBM ROM BASIC - used while in interpreter
  1973. Notes:    called by ROM BASIC, but pointed at IRET by BASIC.COM/BASICA.COM
  1974.     BASIC.COM/BASICA.COM do not restore vector on termination
  1975. SeeAlso: INT 80"BASIC",INT BF"BASIC",INT C1"BASIC"
  1976. --------d-C0---------------------------------
  1977. INT C0 - AMI BIOS - DRIVE 0 DATA
  1978. Note:    this vector is used by some AMI BIOSes to store the first four bytes
  1979.       of the hard disk parameter table
  1980. SeeAlso: INT 41"HARD DISK 0",INT 60"Adaptec",INT C1"AMI",INT C2"AMI"
  1981. SeeAlso: INT C3"AMI",INT C4"AMI"
  1982. --------r-C1---------------------------------
  1983. INT C1 - IBM ROM BASIC - used while in interpreter
  1984. Notes:    called by ROM BASIC, but pointed at IRET by BASIC.COM/BASICA.COM
  1985.     BASIC.COM/BASICA.COM do not restore vector on termination
  1986. SeeAlso: INT 80"BASIC",INT C0"BASIC",INT C2"BASIC"
  1987. --------d-C1---------------------------------
  1988. INT C1 - AMI BIOS - DRIVE 0 DATA
  1989. Note:    this vector is used by some AMI BIOSes to store the second four bytes
  1990.       of the hard disk parameter table
  1991. SeeAlso: INT 41"HARD DISK 0",INT 60"Adaptec",INT C0"AMI",INT C2"AMI"
  1992. SeeAlso: INT C3"AMI"
  1993. --------r-C2---------------------------------
  1994. INT C2 - IBM ROM BASIC - used while in interpreter
  1995. Notes:    called by ROM BASIC, but pointed at IRET by BASIC.COM/BASICA.COM
  1996.     BASIC.COM/BASICA.COM do not restore vector on termination
  1997. SeeAlso: INT 80"BASIC",INT C1"BASIC",INT C3"BASIC"
  1998. --------d-C2---------------------------------
  1999. INT C2 - AMI BIOS - DRIVE 0 DATA
  2000. Note:    this vector is used by some AMI BIOSes to store the third four bytes
  2001.       of the hard disk parameter table
  2002. SeeAlso: INT 41"DISK 0",INT 60"Adaptec",INT C0"AMI",INT C1"AMI",INT C3"AMI"
  2003. --------r-C3---------------------------------
  2004. INT C3 - IBM ROM BASIC - used while in interpreter
  2005. Notes:    called by ROM BASIC, but pointed at IRET by BASIC.COM/BASICA.COM
  2006.     BASIC.COM/BASICA.COM do not restore vector on termination
  2007. SeeAlso: INT 80"BASIC",INT C2"BASIC",INT C4"BASIC"
  2008. --------d-C3---------------------------------
  2009. INT C3 - AMI BIOS - DRIVE 0 DATA
  2010. Note:    this vector is used by some AMI BIOSes to store the final four bytes
  2011.       of the hard disk parameter table
  2012. SeeAlso: INT 41"DISK 0",INT 60"Adaptec",INT C0"AMI",INT C1"AMI",INT C2"AMI"
  2013. --------r-C4---------------------------------
  2014. INT C4 - IBM ROM BASIC - used while in interpreter
  2015. Notes:    called by ROM BASIC, but pointed at IRET by BASIC.COM/BASICA.COM
  2016.     BASIC.COM/BASICA.COM do not restore vector on termination
  2017. SeeAlso: INT 80"BASIC",INT C3"BASIC",INT C5"BASIC"
  2018. --------d-C4---------------------------------
  2019. INT C4 - AMI BIOS - DRIVE 1 DATA
  2020. Note:    this vector is used by some AMI BIOSes to store the first four bytes
  2021.       of the second hard disk's parameter table
  2022. SeeAlso: INT 46"HARD DISK 1",INT 64"Adaptec",INT C0"AMI",INT C5"AMI"
  2023. SeeAlso: INT C6"AMI",INT C7"AMI"
  2024. --------r-C5---------------------------------
  2025. INT C5 - IBM ROM BASIC - used while in interpreter
  2026. Notes:    called by ROM BASIC
  2027.     BASIC.COM/BASICA.COM do not restore vector on termination
  2028. SeeAlso: INT 80"BASIC",INT C4"BASIC",INT C6"BASIC"
  2029. --------d-C5---------------------------------
  2030. INT C5 - AMI BIOS - DRIVE 1 DATA
  2031. Note:    this vector is used by some AMI BIOSes to store the second four bytes
  2032.       of the second hard disk's parameter table
  2033. SeeAlso: INT 46"HARD DISK 1",INT 64"Adaptec",INT C0"AMI",INT C4"AMI"
  2034. SeeAlso: INT C6"AMI",INT C7"AMI"
  2035. --------r-C6---------------------------------
  2036. INT C6 - IBM ROM BASIC - used while in interpreter
  2037. Notes:    called by ROM BASIC, but pointed at IRET by BASIC.COM/BASICA.COM
  2038.     BASIC.COM/BASICA.COM do not restore vector on termination
  2039. SeeAlso: INT 80"BASIC",INT C5"BASIC",INT C7"BASIC"
  2040. --------r-C6---------------------------------
  2041. INT C6 - APL*PLUS/PC - IDENTICAL TO INT 86
  2042. Note:    STSC moved its interrupts from 86h-8Ch to C6h-CCh, but did not delete
  2043.       the older interrupts
  2044. SeeAlso: INT 86"APL"
  2045. --------d-C6---------------------------------
  2046. INT C6 - AMI BIOS - DRIVE 1 DATA
  2047. Note:    this vector is used by some AMI BIOSes to store the third four bytes
  2048.       of the second hard disk's parameter table
  2049. SeeAlso: INT 46"HARD DISK 1",INT 64"Adaptec",INT C0"AMI",INT C4"AMI"
  2050. SeeAlso: INT C5"AMI",INT C7"AMI"
  2051. --------r-C7---------------------------------
  2052. INT C7 - IBM ROM BASIC - used while in interpreter
  2053. Notes:    called by ROM BASIC, but pointed at IRET by BASIC.COM/BASICA.COM
  2054.     BASIC.COM/BASICA.COM do not restore vector on termination
  2055. SeeAlso: INT 80"BASIC",INT C6"BASIC",INT C8"BASIC"
  2056. --------r-C7---------------------------------
  2057. INT C7 - APL*PLUS/PC - ???
  2058. Note:    STSC moved its interrupts from 86h-8Ch to C6h-CCh, but did not delete
  2059.       the older interrupts
  2060. SeeAlso: INT 87"APL"
  2061. --------d-C7---------------------------------
  2062. INT C7 - AMI BIOS - DRIVE 1 DATA
  2063. Note:    this vector is used by some AMI BIOSes to store the final four bytes
  2064.       of the second hard disk's parameter table
  2065. SeeAlso: INT 46"HARD DISK 1",INT 64"Adaptec",INT C0"AMI",INT C4"AMI"
  2066. SeeAlso: INT C5"AMI",INT C6"AMI"
  2067. --------r-C8---------------------------------
  2068. INT C8 - IBM ROM BASIC - used while in interpreter
  2069. Notes:    called by ROM BASIC, but pointed at IRET by BASIC.COM/BASICA.COM
  2070.     BASIC.COM/BASICA.COM do not restore vector on termination
  2071. SeeAlso: INT 80"BASIC",INT C7"BASIC",INT C9"BASIC"
  2072. --------r-C8---------------------------------
  2073. INT C8 - APL*PLUS/PC - IDENTICAL TO INT 88
  2074. Note:    STSC moved its interrupts from 86h-8Ch to C6h-CCh, but did not delete
  2075.       the older interrupts
  2076. SeeAlso: INT 88"APL"
  2077. --------r-C9---------------------------------
  2078. INT C9 - IBM ROM BASIC - used while in interpreter
  2079. Notes:    called by ROM BASIC, but pointed at IRET by BASIC.COM/BASICA.COM
  2080.     BASIC.COM/BASICA.COM do not restore vector on termination
  2081. SeeAlso: INT 80"BASIC",INT C8"BASIC",INT CA"BASIC"
  2082. --------r-C9---------------------------------
  2083. INT C9 - APL*PLUS/PC - ???
  2084. Note:    STSC moved its interrupts from 86h-8Ch to C6h-CCh, but did not delete
  2085.       the older interrupts
  2086. SeeAlso: INT 89"APL"
  2087. --------r-CA---------------------------------
  2088. INT CA - IBM ROM BASIC - used while in interpreter
  2089. Notes:    called by ROM BASIC, but pointed at IRET by BASIC.COM/BASICA.COM
  2090.     BASIC.COM/BASICA.COM do not restore vector on termination
  2091. SeeAlso: INT 80"BASIC",INT C9"BASIC",INT CB"BASIC"
  2092. --------r-CA---------------------------------
  2093. INT CA - APL*PLUS/PC - PRINT SCREEN
  2094. Note:    STSC moved its interrupts from 86h-8Ch to C6h-CCh, but did not delete
  2095.       the older interrupts
  2096. SeeAlso: INT 8A"APL"
  2097. --------r-CB---------------------------------
  2098. INT CB - IBM ROM BASIC - used while in interpreter
  2099. Notes:    called by ROM BASIC, but pointed at IRET by BASIC.COM/BASICA.COM
  2100.     BASIC.COM/BASICA.COM do not restore vector on termination
  2101. SeeAlso: INT 80"BASIC",INT CA"BASIC",INT CC"BASIC"
  2102. --------r-CB---------------------------------
  2103. INT CB - APL*PLUS/PC - BEEP
  2104. Notes:    STSC moved its interrupts from 86h-8Ch to C6h-CCh, but did not delete
  2105.       the older interrupts
  2106.     same as printing a ^G via INT 21/AH=02h
  2107. SeeAlso: INT 8B"APL"
  2108. --------r-CC---------------------------------
  2109. INT CC - IBM ROM BASIC - used while in interpreter
  2110. Notes:    called by ROM BASIC, but pointed at IRET by BASIC.COM/BASICA.COM
  2111.     BASIC.COM/BASICA.COM do not restore vector on termination
  2112. SeeAlso: INT 80"BASIC",INT CB"BASIC",INT CD"BASIC"
  2113. --------r-CC---------------------------------
  2114. INT CC - APL*PLUS/PC - CLEAR SCREEN MEMORY
  2115.     AX = flag
  2116.         0000h do not save display attributes
  2117.         0001h save attributes
  2118. Note:    STSC moved its interrupts from 86h-8Ch to C6h-CCh, but did not delete
  2119.       the older interrupts
  2120. SeeAlso: INT 8C"APL"
  2121. --------r-CD---------------------------------
  2122. INT CD - IBM ROM BASIC - used while in interpreter
  2123. Notes:    called by ROM BASIC, but pointed at IRET by BASIC.COM/BASICA.COM
  2124.     BASIC.COM/BASICA.COM do not restore vector on termination
  2125. SeeAlso: INT 80"BASIC",INT CC"BASIC",INT CE"BASIC"
  2126. --------r-CD---------------------------------
  2127. INT CD - STSC APL*PLUS/PC - MAY BE USED IN FUTURE RELEASES
  2128. --------r-CE---------------------------------
  2129. INT CE - IBM ROM BASIC - used while in interpreter
  2130. Notes:    called by ROM BASIC, but pointed at IRET by BASIC.COM/BASICA.COM
  2131.     BASIC.COM/BASICA.COM do not restore vector on termination
  2132. SeeAlso: INT 80"BASIC",INT CD"BASIC",INT CF"BASIC"
  2133. --------r-CE---------------------------------
  2134. INT CE - STSC APL*PLUS/PC - MAY BE USED IN FUTURE RELEASES
  2135. --------r-CF---------------------------------
  2136. INT CF - IBM ROM BASIC - used while in interpreter
  2137. Notes:    called by ROM BASIC, but pointed at IRET by BASIC.COM/BASICA.COM
  2138.     BASIC.COM/BASICA.COM do not restore vector on termination
  2139. SeeAlso: INT 80"BASIC",INT CE"BASIC",INT D0"BASIC"
  2140. --------r-CF---------------------------------
  2141. INT CF - APL*PLUS/PC - DEFAULT LOW-RESOLUTION TIMER FOR QUAD MF FUNCTION
  2142. SeeAlso: INT E0"APL"
  2143. --------r-D0---------------------------------
  2144. INT D0 - IBM ROM BASIC - used while in interpreter
  2145. Notes:    called by ROM BASIC, but pointed at IRET by BASIC.COM/BASICA.COM
  2146.     BASIC.COM/BASICA.COM do not restore vector on termination
  2147. SeeAlso: INT 80"BASIC",INT CF"BASIC",INT D1"BASIC"
  2148. --------r-D0---------------------------------
  2149. INT D0 - STSC APL*PLUS/PC - MAY BE USED IN FUTURE RELEASES
  2150. --------U-D0---------------------------------
  2151. INT D0 - [not a vector!] - NJFRERAM SIGNATURE VECTOR
  2152. Program: NJFRERAM is a resident free-memory display utility by Mike "Nifty
  2153.       James" Blaszczak
  2154. Note:    if NJFRERAM is installed, this vector points at the signature "NJ"
  2155. Index:    installation check;NJFRERAM
  2156. --------r-D1---------------------------------
  2157. INT D1 - IBM ROM BASIC - used while in interpreter
  2158. Notes:    called by ROM BASIC, but pointed at IRET by BASIC.COM/BASICA.COM
  2159.     BASIC.COM/BASICA.COM do not restore vector on termination
  2160. SeeAlso: INT 80"BASIC",INT D0"BASIC",INT D2"BASIC"
  2161. --------r-D1---------------------------------
  2162. INT D1 - STSC APL*PLUS/PC - MAY BE USED IN FUTURE RELEASES
  2163. --------r-D2---------------------------------
  2164. INT D2 - IBM ROM BASIC - used while in interpreter
  2165. Notes:    called by ROM BASIC, but pointed at IRET by BASIC.COM/BASICA.COM
  2166.     BASIC.COM/BASICA.COM do not restore vector on termination
  2167. SeeAlso: INT 80"BASIC",INT D1"BASIC",INT D3"BASIC"
  2168. --------r-D2---------------------------------
  2169. INT D2 - STSC APL*PLUS/PC - MAY BE USED IN FUTURE RELEASES
  2170. --------r-D3---------------------------------
  2171. INT D3 - IBM ROM BASIC - used while in interpreter
  2172. Notes:    called by ROM BASIC, but pointed at IRET by BASIC.COM/BASICA.COM
  2173.     BASIC.COM/BASICA.COM do not restore vector on termination
  2174. SeeAlso: INT 80"BASIC",INT D2"BASIC",INT D4"BASIC"
  2175. --------r-D3---------------------------------
  2176. INT D3 - STSC APL*PLUS/PC - MAY BE USED IN FUTURE RELEASES
  2177. --------v-D3---------------------------------
  2178. INT D3 - VIRUS - "Antiexe" - RELOCATED INT 13
  2179. SeeAlso: INT 9F"VIRUS"
  2180. --------r-D4---------------------------------
  2181. INT D4 - IBM ROM BASIC - used while in interpreter
  2182. Notes:    called by ROM BASIC
  2183.     BASIC.COM/BASICA.COM do not restore vector on termination
  2184. SeeAlso: INT 80"BASIC",INT D3"BASIC",INT D5"BASIC"
  2185. --------r-D4---------------------------------
  2186. INT D4 - STSC APL*PLUS/PC - MAY BE USED IN FUTURE RELEASES
  2187. --------O-D400-------------------------------
  2188. INT D4 O - PC-MOS/386 v5.01 - OBSOLETE FUNCTIONS
  2189.     AH = 00h and 01h
  2190. Return: nothing
  2191. Desc:    PC-MOS/386 v5.01 reports that these functions are no longer supported
  2192.       and enters an endless loop
  2193. Program: PC-MOS/386 is a multitasking/multiuser MS-DOS-compatible operating
  2194.       system by The Software Link, Inc.
  2195. --------O-D402-------------------------------
  2196. INT D4 - PC-MOS/386 v3.0+ - GET SYSTEM CONTROL BLOCK POINTER
  2197.     AH = 02h
  2198. Return: AX = 0000h
  2199.     ES:BX -> System Control Block in V86 mode (see #3253)
  2200.     ES:EBX -> System Control Block in native mode (see #3253)
  2201. Note:    superseded by AH=26h
  2202. SeeAlso: AH=04h,AH=10h,AH=26h,AH=28h,AH=29h,AH=2Ah,INT 21/AX=3000h,INT 38
  2203.  
  2204. Format of PC-MOS/386 System Control Block:
  2205. Offset    Size    Description    (Table 3253)
  2206.  00h    WORD    pointer to first TCB in chain
  2207.  02h 17 BYTEs    reserved
  2208.  13h    WORD    pointer to current task's TCB
  2209.  15h    WORD    pointer to TCB of visible (console) task
  2210. --------O-D403-------------------------------
  2211. INT D4 - PC-MOS/386 v5.01 - GET/SET EXTENDED DIRECTORY INFORMATION
  2212.     AH = 03h
  2213.     AL = subfunction (00h get, 01h set)
  2214.     DS:(E)DX -> pathname
  2215.     ES:(E)BX -> 10-byte buffer for directory information (see #3254)
  2216. Return: CF clear if successful
  2217.         AL = permitted access level for file (00h-03h)
  2218.         ES:(E)BX -> modified buffer (AL=01h on entry)
  2219.     CF set on error
  2220.         AX = error code (see #1020 at INT 21/AH=59h/BX=0000h)
  2221. Notes:    BX/DX are used in V86 mode, EBX/EDX in native mode
  2222.     the file class cannot be changed for files because it affects the
  2223.       encryption method, but directories can have their classes changed
  2224.  
  2225. Format of PC-MOS/386 directory information:
  2226. Offset    Size    Description    (Table 3254)
  2227.  00h    BYTE    reserved (0)
  2228.  01h    BYTE    file class ('A'-'Z' or 00h)
  2229.  02h    DWORD    user ID of file creator
  2230.  06h    WORD    file creation time (see #1005 at INT 21/AX=5700h)
  2231.  08h    WORD    file creation date (see #1006 at INT 21/AX=5700h)
  2232. --------O-D404-------------------------------
  2233. INT D4 - PC-MOS/386 v3.0+ - GET TASK CONTROL BLOCK
  2234.     AH = 04h
  2235.     BX = task ID or FFFFh for calling task
  2236. Return: CF clear if successful
  2237.         ES = segment of Task Control Block (TCB) (see #3255)
  2238.     CF set on error
  2239.         AX = error code (see #1020 at INT 21/AH=59h/BX=0000h)
  2240. Note:    superseded by AH=27h
  2241. SeeAlso: AH=02h,AH=27h,AH=28h,AH=29h,AH=2Ah,INT 38
  2242.  
  2243. Format of PC-MOS/386 Task Control Block:
  2244. Offset    Size    Description    (Table 3255)
  2245.  00h    BYTE    signature byte "H" if allocated from system memory pool
  2246.  01h    BYTE    header block ID, "T" = TCB
  2247.  02h    WORD    length of block in paragraphs
  2248.  04h    WORD    segment address of next header block (0000h if last)
  2249.  06h    WORD    segment address of previous header block (0000h if first)
  2250.  08h    WORD    pointer to next TCB
  2251.  0Ah    WORD    pointer to previous TCB
  2252.  0Ch    WORD    pointer to associated TCB (if applicable)
  2253.  0Eh    WORD    reserved
  2254. ---TCB---
  2255.  10h    WORD    TCB task ID
  2256.  12h    WORD    native context save area
  2257.  14h    WORD    start address of task
  2258.  16h    WORD    end address of task
  2259.  18h    BYTE    task priority
  2260.  19h    BYTE    task time slice
  2261.  1Ah    BYTE    "TCBWAIT" run status of task
  2262.  1Bh    BYTE    "TCBSTAT" what the task is waiting for
  2263.  1Ch    DWORD    address of polling routine
  2264.  20h    BYTE    error code from last function call
  2265.  21h 11 BYTEs    name of currently executing task
  2266.  2Ch  4 BYTEs    ???
  2267.  30h    BYTE    keyboard disabled if bit 1 set
  2268.  31h    BYTE    current shift state and toggles
  2269.  32h  2 BYTEs    ???
  2270.  34h    BYTE    current video mode
  2271.  35h    BYTE    current video page
  2272.  36h    BYTE    number of text columns per screen
  2273.  37h    BYTE    number of text rows per screen
  2274.  38h    WORD    length of video buffer
  2275.  3Ah    WORD    video page length
  2276.  3Ch    WORD    apge start address in video RAM
  2277.  3Eh  4 WORDs    current cursor positions for four screen pages
  2278.  46h  8 BYTEs    ???
  2279.  4Eh    WORD    current cursor type
  2280.  50h    BYTE    current palette setting
  2281.  51h    BYTE    original video mode
  2282.  52h    BYTE    start CRT row (00h or 01h)
  2283.  53h    BYTE    video RAM in task active
  2284.  54h    WORD    handle of video save area
  2285.  56h    WORD    page count of video save area
  2286.  58h    WORD    segment address of video save area
  2287.  5Ah    WORD    poitner to first Task File Block (see #3258)
  2288.  5Ch    WORD    pointer to first Current Directory Block (see #3261)
  2289.  5Eh    WORD    pointer to active Current Directory Block (see #3261)
  2290.  60h    BYTE    number of drives
  2291.  61h    BYTE    current drive (0=A:, etc.)
  2292.  62h    DWORD    disk transfer address
  2293.  66h  4 BYTEs    ???
  2294.  6Ah    BYTE    verify flag (nonzero = on)
  2295.  6Bh    BYTE    break flag (nonzero = on)
  2296.  6Ch    WORD    share/lock retry count
  2297.  6Eh    WORD    ticks between share/lock retries
  2298.  70h    BYTE    remote printer flags (see #3256)
  2299.  71h    BYTE    ETX/ACK delay count
  2300.  72h    WORD    spooler segment address
  2301.  74h  2 BYTEs    ???
  2302.  76h  3 BYTEs    remote printer redirection for LPT1 through LPT3 (see #3257)
  2303.  79h  2 BYTEs    ???
  2304.  7Bh    DWORD    offset of username in TCB
  2305.  7Fh    BYTE    current output class
  2306.  80h  7 BYTEs    protection access rights, 2 bits per class (writeable!)
  2307.  87h 122 BYTEs    ???
  2308. 101h    BYTE    TCB sleep downcounter value
  2309. 102h 20 BYTEs    ???
  2310. 116h    BYTE    last scan code
  2311.     ...
  2312. 5D0h    DWORD    far pointer to Device Driver Terminal's entry point
  2313. 5D4h    WORD    offset of logical screen
  2314. 5D6h    WORD    segment of logical screen
  2315. 5D8h    WORD    cursor offset within page
  2316. 5DAh    BYTE    screen columns
  2317. 5DBh    WORD    async port number (0000h = none)
  2318. 5DDh    DWORD    physical baudrate
  2319. 5E1h 19 BYTEs    reserved for Device Driver Terminal (DDT)
  2320.     ...
  2321. 7A6h    DWORD    far pointer to unregister calling chain
  2322.  
  2323. Bitfields for PC-MOS/386 remote printer flags:
  2324. Bit(s)    Description    (Table 3256)
  2325.  0    LPT1 to terminal
  2326.  1    LPT2 to terminal
  2327.  2    LPT3 to terminal
  2328.  3    escape to printer pending
  2329.  4    use XON/XOFF
  2330.  5    use ETX/ACK
  2331.  6    waiting for ACK or XON
  2332.  7    transparent printing on
  2333.  
  2334. (Table 3257)
  2335. Values for PC-MOS/386 remote printer redirection:
  2336.  00h    not redirected
  2337.  01h    redirected to COM1
  2338.  ...
  2339.  18h    redirected to COM24
  2340.  51h    redirected to LPT1
  2341.  52h    redirected to LPT2
  2342.  53h    redirected to LPT3
  2343.  
  2344. Format of PC-MOS/386 Task File Block:
  2345. Offset    Size    Description    (Table 3258)
  2346.  00h    BYTE    signature byte "H" if allocated from system memory pool
  2347.  01h    BYTE    header block ID, "F" = task file block
  2348.  02h    WORD    length of block in paragraphs
  2349.  04h    WORD    segment address of next header block (0000h if last)
  2350.  06h    WORD    segment address of previous header block (0000h if first)
  2351.  08h    WORD    pointer to next TCB
  2352.  0Ah    WORD    pointer to previous TCB
  2353.  0Ch    WORD    pointer to associated TCB (if applicable)
  2354.  0Eh    WORD    reserved
  2355. ---TFB---
  2356.  10h    WORD    segment address of next TFB
  2357.  12h    WORD    segment address of previous TFB
  2358.  14h    WORD    segment address of TFB's Global File Block (see #3260)
  2359.  16h    WORD    segment address of owner's PSP
  2360.  18h    WORD    file handle
  2361.  1Ah  3 BYTEs    ???
  2362.  1Dh    DWORD    file position
  2363.  21h  4 BYTEs    ???
  2364.  25h    BYTE    IOCTL flags (see #3259)
  2365.  26h  2 BYTEs    ???
  2366.  
  2367. Bitfields for PC-MOS/386 IOCTL flags:
  2368. Bit(s)    Description    (Table 3259)
  2369.  0    stdin
  2370.  1    stdout
  2371.  2    null device
  2372.  3    clock device
  2373.  4    reserved
  2374.  5    ASCII mode instead of binary
  2375.  6    EOF encountered on input
  2376.  7    device rather than file
  2377.  
  2378. Format of PC-MOS/386 Global File Block:
  2379. Offset    Size    Description    (Table 3260)
  2380.  00h    BYTE    signature byte "H" if allocated from system memory pool
  2381.  01h    BYTE    header block ID, "G" = global file block
  2382.  02h    WORD    length of block in paragraphs
  2383.  04h    WORD    segment address of next header block (0000h if last)
  2384.  06h    WORD    segment address of previous header block (0000h if first)
  2385.  08h    WORD    pointer to next TCB
  2386.  0Ah    WORD    pointer to previous TCB
  2387.  0Ch    WORD    pointer to associated TCB (if applicable)
  2388.  0Eh    WORD    reserved
  2389. ---GFB---
  2390.  10h 10 BYTEs    ???
  2391.  1Ah    WORD    file attribute
  2392.  1Ch    BYTE    ???
  2393.  1Dh    DWORD    address of device driver
  2394.  21h    WORD    first cluster
  2395.  23h    WORD    time of last modification
  2396.  25h    WORD    date of last modification
  2397.  27h    DWORD    size of file in bytes
  2398.  2Bh 11 BYTEs    ???
  2399.  36h 11 BYTEs    device name or FCB-format filename
  2400.  41h    WORD    segment address of TFB list
  2401.  43h    WORD    segment address of first RLB (see #3263) (0000h = none)
  2402.  45h    BYTE    flag: nonzero if GFB refers to character device
  2403.  46h    WORD    address of Block Device Block (see #3262)
  2404.  48h    WORD    sector of file's directory entry (see #0700)
  2405.  4Ah    WORD    high word of file's directory entry
  2406.  4Ch    WORD    ofsset of directory entry within sector
  2407.  
  2408. Format of PC-MOS/386 Current Directory Block:
  2409. Offset    Size    Description    (Table 3261)
  2410.  00h    BYTE    signature byte "H" if allocated from system memory pool
  2411.  01h    BYTE    header block ID, "C" = current directory block
  2412.  02h    WORD    length of block in paragraphs
  2413.  04h    WORD    segment address of next header block (0000h if last)
  2414.  06h    WORD    segment address of previous header block (0000h if first)
  2415.  08h    WORD    pointer to next TCB
  2416.  0Ah    WORD    pointer to previous TCB
  2417.  0Ch    WORD    pointer to associated TCB (if applicable)
  2418.  0Eh    WORD    reserved
  2419. ---CDB---
  2420.  10h    BYTE    drive number
  2421.  11h    BYTE    ???
  2422.  12h 64 BYTEs    directory name
  2423.  52h    WORD    first directory cluster (0000h = root)
  2424.  
  2425. Format of PC-MOS/386 Block Device Block:
  2426. Offset    Size    Description    (Table 3262)
  2427.  00h    BYTE    signature byte "H" if allocated from system memory pool
  2428.  01h    BYTE    header block ID, "B" = block device block
  2429.  02h    WORD    length of block in paragraphs
  2430.  04h    WORD    segment address of next header block (0000h if last)
  2431.  06h    WORD    segment address of previous header block (0000h if first)
  2432.  08h    WORD    pointer to next TCB
  2433.  0Ah    WORD    pointer to previous TCB
  2434.  0Ch    WORD    pointer to associated TCB (if applicable)
  2435.  0Eh    WORD    reserved
  2436. ---BDB---
  2437.  10h    BYTE    logical drive
  2438.  11h    BYTE    unit passed to driver
  2439.  12h    WORD    sector size
  2440.  14h    BYTE    cluster mask
  2441.  15h    BYTE    cluster shift count
  2442.  16h    WORD    starting sector of first FAT
  2443.  18h    BYTE    number of FATs
  2444.  19h    WORD    number of root directories
  2445.  1Bh    WORD    sector number of first data sector (cluster 0002h)
  2446.  1Dh    WORD    number of clusters + 1 (number of highest data cluster)
  2447.  1Fh    BYTE    number of sectors in FAT
  2448.  20h    WORD    beginning root directory sector number
  2449.  22h    DWORD    device driver address
  2450.  26h    BYTE    media descriptor byte
  2451.  27h  5 BYTEs    ???
  2452.  2Ch    BYTE    flag: volume > 32MB
  2453.  2Dh    BYTE    ???
  2454.  2Eh    BYTE    number of sectors per cluster
  2455.  2Fh    WORD    number of clusters on device
  2456.  31h    WORD    number of free clusters (FFFFh = unknown)
  2457.  33h    WORD    root directory cluster number
  2458.  35h    WORD    pointer to alias/subst string
  2459.  37h    WORD    TCB segment address of owner (0000h = none)
  2460.  
  2461. Format of PC-MOS/386 Record Lock Block:
  2462. Offset    Size    Description    (Table 3263)
  2463.  00h    BYTE    signature byte "H" if allocated from system memory pool
  2464.  01h    BYTE    header block ID, "R" = record lock block
  2465.  02h    WORD    length of block in paragraphs
  2466.  04h    WORD    segment address of next header block (0000h if last)
  2467.  06h    WORD    segment address of previous header block (0000h if first)
  2468.  08h    WORD    pointer to next TCB
  2469.  0Ah    WORD    pointer to previous TCB
  2470.  0Ch    WORD    pointer to associated TCB (if applicable)
  2471.  0Eh    WORD    reserved
  2472. ---RLB---
  2473.  10h    WORD    segment address of owner's PSP
  2474.  12h    WORD    segment address of Global File Block (see #3260)
  2475.  14h    WORD    segment address of owner's Task File Block (see #3258)
  2476.  16h    DWORD    file offset of locked region start
  2477.  1Ah    DWORD    length of locked region
  2478.  1Eh    WORD    owner's handle for file
  2479. --------O-D407-------------------------------
  2480. INT D4 - PC-MOS/386 v3.0+ - WAIT FOR EVENT
  2481.     AH = 07h
  2482.     AL = events to monitor (see #3264)
  2483.     BX = number of timer ticks until timeout if AL bit 1 set
  2484.     CX = bitmap of IRQs to monitor if AL bit 2 set
  2485.         (bit 0 = IRQ0 .. bit 15 = IRQ15)
  2486.     DX = port to monitor if AL bit 3 set
  2487. Return: CF clear if successful
  2488.         AL = type of event which woke up task (see #3264)
  2489.         CX = IRQ (if any) which awakened task
  2490.         DX = port (if any) which awakened task
  2491.     CF set on error
  2492.         AX = error code (see #1020 at INT 21/AH=59h/BX=0000h)
  2493. Note:    a device driver may make this call with AL=00h, which indicates that
  2494.       the driver is responsible for setting and clearing the TCBWAIT field
  2495.       in the TCB.  To put task to sleep, set TCBWAIT bits 2-0 to 001; to
  2496.       reawaken it, set bit 1 (leaving other bits unchanged)
  2497. SeeAlso: AH=04h,INT 16/AH=00h,INT 38
  2498.  
  2499. Bitfields for PC-MOS/386 events to monitor:
  2500. Bit(s)    Description    (Table 3264)
  2501.  0    keystroke
  2502.  1    timeout
  2503.  2    IRQ
  2504.  3    port access
  2505.  7    return status of user poll routine (other ignored if set)
  2506. --------O-D410-------------------------------
  2507. INT D4 - PC-MOS/386 v3.0+ - ENTER/LEAVE NATIVE 386 EXECUTION MODE
  2508.     AH = 10h
  2509.     AL = direction (00h return to V86 mode, 01h enter native mode)
  2510.     CX = length in bytes of Native Context Area ( >=1024 )
  2511.     DX = segment of Native Context Area
  2512. Return: CF clear if successful
  2513.         running in desired mode at instruction following INT D4 call
  2514.         all segment registers converted to appropriate selectors/segments
  2515.     CF set on error
  2516.         AX = error code (see #1020 at INT 21/AH=59h/BX=0000h)
  2517. Note:    MS-DOS calls are available in protected mode
  2518. SeeAlso: AH=11h,AH=12h,AH=13h,INT 2F/AX=1687h,INT 67/AX=DE0Ch,INT 38
  2519. --------O-D411-------------------------------
  2520. INT D4 - PC-MOS/386 v3.0+ - ALLOCATE NATIVE MODE MEMORY BLOCK
  2521.     AH = 11h
  2522.     EBX = block length in bytes
  2523. Return: CF clear if successful
  2524.         EBX = number of bytes actually allocated
  2525.         ES = selector for allocated block
  2526.     CF set on error
  2527.         AX = error code (see #1020 at INT 21/AH=59h/BX=0000h)
  2528. Program: PC-MOS/386 is a multitasking/multiuser MS-DOS-compatible operating
  2529.       system by The Software Link, Inc.
  2530. Note:    the memory must be released before the program terminates
  2531. SeeAlso: AH=10h,AH=12h,INT 38
  2532. --------O-D412-------------------------------
  2533. INT D4 - PC-MOS/386 v3.0+ - FREE NATIVE MODE MEMORY BLOCK
  2534.     AH = 12h
  2535.     ES = selector for block to free
  2536. Return: CF clear if successful
  2537.     CF set on error
  2538.         AX = error code (see #1020 at INT 21/AH=59h/BX=0000h)
  2539. SeeAlso: AH=10h,AH=11h,AH=13h,INT 38
  2540. --------O-D413-------------------------------
  2541. INT D4 - PC-MOS/386 v5.01 - GET ALIAS FOR SELECTOR (NATIVE MODE ONLY)
  2542.     AH = 13h
  2543.     AL = type of alias selector (00h data, 01h stack, 02h code)
  2544.     BX = selector
  2545. Return: CF clear if successful
  2546.         AX = new selector or 0000h if BX selector not found
  2547.     CF set on error
  2548.         AX = error code (see #1020 at INT 21/AH=59h/BX=0000h)
  2549. SeeAlso: AH=11h,AH=12h
  2550. --------O-D416-------------------------------
  2551. INT D4 - PC-MOS/386 v5.01 - SET/CLEAR IRQ RESERVATION
  2552.     AH = 16h
  2553.     AL = function (00h clear, 01h set reservation)
  2554.     CX = IRQ number
  2555. Return: AX = status
  2556.         (0000h successful, 0001h currently reserved by another task)
  2557. SeeAlso: AH=07h,INT 14/AH=11h"PC-MOS"
  2558. --------O-D419-------------------------------
  2559. INT D4 - PC-MOS/386 v5.01 - GET TASK ID
  2560.     AH = 19h
  2561. Return: BX = caller's task ID
  2562. Program: PC-MOS/386 is a multitasking/multiuser MS-DOS-compatible operating
  2563.       system by The Software Link, Inc.
  2564. SeeAlso: AH=1Dh,AH=1Eh
  2565. --------O-D41A-------------------------------
  2566. INT D4 - PC-MOS/386 v5.01 - GET/SET TASK PRIORITY
  2567.     AH = 1Ah
  2568.     AL = subfunction (00h read, 01h set, 02h get and set)
  2569.     BX = task ID (FFFFh for current task)
  2570.     CL = new priority value
  2571. Return: CF clear if successful
  2572.         CL = current priority value
  2573.     CF set on error
  2574.         AX = error code (see #1020 at INT 21/AH=59h/BX=0000h)
  2575. SeeAlso: AH=1Bh,AH=1Ch
  2576. --------O-D41B-------------------------------
  2577. INT D4 - PC-MOS/386 v5.01 - GET/SET TIME SLICE
  2578.     AH = 1Bh
  2579.     AL = subfunction (00h read, 01h set, 02h get and set)
  2580.     BX = task ID (FFFFh for current task) (see AH=19h)
  2581.     CL = new time slice value
  2582. Return: CF clear if successful
  2583.         CL = current time slice value
  2584.     CF set on error
  2585.         AX = error code (see #1020 at INT 21/AH=59h/BX=0000h)
  2586. SeeAlso: AH=1Ah,AH=1Ch
  2587. --------O-D41C-------------------------------
  2588. INT D4 - PC-MOS/386 v5.01 - GET/SET KEYBOARD MODE
  2589.     AH = 1Ch
  2590.     AL = subfunction (00h enable, 01h disable, 02h get mode)
  2591.     BX = task ID (FFFFh for current task)
  2592. Return: CF clear if successful
  2593.         CL = current keyboard state
  2594.     CF set on error
  2595.         AX = error code (see #1020 at INT 21/AH=59h/BX=0000h)
  2596. Program: PC-MOS/386 is a multitasking/multiuser MS-DOS-compatible operating
  2597.       system by The Software Link, Inc.
  2598. SeeAlso: AH=1Ah,AH=1Bh
  2599. --------O-D41D-------------------------------
  2600. INT D4 - PC-MOS/386 v5.01 - GET CURRENT PROGRAM NAME
  2601.     AH = 1Dh
  2602.     BX = task ID (FFFFh for current task) (see AH=19h)
  2603.     ES:DI -> buffer for program name (see #3265)
  2604. Return: CF clear if successful
  2605.         ES:DI buffer filled
  2606.     CF set on error
  2607.         AX = error code (see #1020 at INT 21/AH=59h/BX=0000h)
  2608. SeeAlso: AH=19h,AH=1Eh
  2609.  
  2610. Format of PC-MOS/386 program name buffer:
  2611. Offset    Size    Description    (Table 3265)
  2612.  00h  8 BYTEs    filename
  2613.  08h  3 BYTEs    extension
  2614. --------O-D41E-------------------------------
  2615. INT D4 - PC-MOS/386 v5.01 - GET CURRENT USERNAME AND SECURITY CLASS
  2616.     AH = 1Eh
  2617.     BX = task ID (FFFFh for current task)
  2618.     ES:DI -> 4-byte buffer for username
  2619. Return: CF clear if successful
  2620.         CL = security class
  2621.         20h (' ') none
  2622.         41h-5Ah ('A'-'Z') security level
  2623.         ES:DI buffer filled
  2624.     CF set on error
  2625.         AX = error code (see #1020 at INT 21/AH=59h/BX=0000h)
  2626. SeeAlso: AH=19h,AH=1Dh
  2627. --------O-D41F-------------------------------
  2628. INT D4 - PC-MOS/386 v5.01 - GET TASK PARTITION INFORMATION
  2629.     AH = 1Fh
  2630.     BX = task ID (FFFFh for current task) (see AH=19h)
  2631. Return: CF clear if successful
  2632.         CX = start segment of task
  2633.         DX = ending segment of task
  2634.     CF set on error
  2635.         AX = error code (see #1020 at INT 21/AH=59h/BX=0000h)
  2636. Program: PC-MOS/386 is a multitasking/multiuser MS-DOS-compatible operating
  2637.       system by The Software Link, Inc.
  2638. SeeAlso: AH=2Dh
  2639. --------O-D420-------------------------------
  2640. INT D4 - PC-MOS/386 v5.01 - GET PORT AND BAUDRATE INFORMATION
  2641.     AH = 20h
  2642.     BX = task ID (FFFFh for current task) (see AH=19h)
  2643. Return: CF clear if successful
  2644.         CX = port number (0000h if none)
  2645.         DI:SI = baudrate (if CX nonzero)
  2646.     CF set on error
  2647.         AX = error code (see #1020 at INT 21/AH=59h/BX=0000h)
  2648. SeeAlso: INT 14/AH=0Ch"FOSSIL"
  2649. --------O-D421-------------------------------
  2650. INT D4 - PC-MOS/386 v5.01 - REMOVE A TASK
  2651.     AH = 21h
  2652.     BX = task ID (FFFFh for current task) (see AH=19h)
  2653. Return: CF clear if successful
  2654.         AX = ASCII percentage of System Memory Pool used
  2655.         (AH = tens digit, AL = ones digit)
  2656.         DS,SI destroyed
  2657.     CF set on error
  2658.         AX = error code (see #1020 at INT 21/AH=59h/BX=0000h)
  2659. Program: PC-MOS/386 is a multitasking/multiuser MS-DOS-compatible operating
  2660.       system by The Software Link, Inc.
  2661. SeeAlso: AH=22h
  2662. --------O-D422-------------------------------
  2663. INT D4 - PC-MOS/386 v5.01 - ADD A TASK TO THE SYSTEM
  2664.     AH = 22h
  2665.     DS:SI -> addtask data structure (see #3267)
  2666. Return: CF clear if successful
  2667.         ES = segment address of the new task's TCB data structure
  2668.     CF set on error
  2669.         AX = error code (see #3266)
  2670. SeeAlso: AH=21h
  2671.  
  2672. (Table 3266)
  2673. Values for PC-MOS/386 error code:
  2674.  08h    insufficient memory
  2675.  0Bh    invalid addtask structure format
  2676.  12h    insufficient available space in system memory pool
  2677.  1Fh    general failure
  2678.  55h    already allocated
  2679.  57h    if task already in use or invalid parameter
  2680.  
  2681. Format of PC-MOS/386 addtask data structure:
  2682. Offset    Size    Description    (Table 3267)
  2683.  00h    WORD    task size in KB (min 16KB)
  2684.  02h    WORD    task ID (0000h for automatic selection)
  2685.  04h    BYTE    task class (' ' or 'A'-'Z')
  2686.  05h    DWORD    -> ASCIZ name of task startup batchfile
  2687.  09h    DWORD    -> task's terminal driver (0000000h = background task)
  2688.  0Dh    WORD    task port
  2689.  0Fh    DWORD    task baud rate
  2690.  13h    DWORD    (ret) total extended memory
  2691.  17h    DWORD    (ret) number of 4K extended memory pages allocated
  2692.  1Bh    WORD    (ret) paragraphs of system memory pool allocated
  2693.  1Dh    WORD    (ret) system memory pool size in paragraphs
  2694.  1Fh    WORD    (ret) ASCII task percentage of system memory pool
  2695.  21h  3 BYTEs    reserved
  2696. --------O-D423-------------------------------
  2697. INT D4 - PC-MOS/386 v5.01 - CHANGE TERMINAL DRIVER
  2698.     AH = 23h
  2699.     BX = task ID (FFFFh for current task)
  2700.     DS:SI -> entry point of the new Device Driver Terminal
  2701. Return: CF clear if successful
  2702.     CF set on error
  2703.         AX = error code (see #1020 at INT 21/AH=59h/BX=0000h)
  2704. --------O-D424-------------------------------
  2705. INT D4 U - PC-MOS/386 v5.01 - GET OPERATING SYSTEM SERIAL NUMBER
  2706.     AH = 24h
  2707. Return: DS:DX -> '$'-terminated string containing the serial number
  2708. --------O-D425-------------------------------
  2709. INT D4 - PC-MOS/386 v5.01 - IDENTIFY LOAD ADDRESS OF DEVICE DRIVER LOCATION
  2710.     AH = 25h
  2711.     DX = driver's CS value
  2712. Return: AX = segment address of driver in system memory pool
  2713.         (0000h if the driver is not within the system memory pool)
  2714. Program: PC-MOS/386 is a multitasking/multiuser MS-DOS-compatible operating
  2715.       system by The Software Link, Inc.
  2716. --------O-D426-------------------------------
  2717. INT D4 - PC-MOS/386 v5.01 - GET SYSTEM CONTROL BLOCK SEGMENT/SELECTOR
  2718.     AH = 26h
  2719. Return: DX = segment/selector of the System Control Block (see #3253)
  2720. Note:    this function supersedes AH=02h
  2721. SeeAlso: AH=02h,AH=27h,AH=28h,AH=29h,AH=2Ah
  2722. --------O-D427-------------------------------
  2723. INT D4 - PC-MOS/386 v5.01 - GET TASK CONTROL BLOCK SEGMENT/SELECTOR
  2724.     AH = 27h
  2725.     BX = task ID (FFFFh if current task) (see AH=19h)
  2726. Return: CF clear if successful
  2727.         DX = segment/selector for the Task Control Block (see #3255)
  2728.     CF set on error
  2729.         AX = error code (see #1020 at INT 21/AH=59h/BX=0000h)
  2730. Note:    this function supersedes AH=04h
  2731. SeeAlso: AH=26h,AH=28h,AH=29h,AH=2Ah
  2732. --------O-D428-------------------------------
  2733. INT D4 - PC-MOS/386 v5.01 - GET CONTROL BLOCK DATA FROM SCB OR TCB
  2734.     AH = 28h
  2735.     BX = offset into control block at which to start reading
  2736.     CX = number of bytes to read
  2737.     DX = segment/selector of control block obtained via AH=26h or AH=27h
  2738.     ES:DI -> buffer for data
  2739. Return: CF clear if successful
  2740.     CF set on error
  2741.         AX = error code (see also #1020 at INT 21/AH=59h/BX=0000h)
  2742.         05h access denied due to an invalid segment/selector
  2743. SeeAlso: AH=26h,AH=27h,AH=29h,AH=2Ah
  2744. --------O-D429-------------------------------
  2745. INT D4 - PC-MOS/386 v5.01 - WRITE CONTROL BLOCK DATA INTO SCB OR TCB
  2746.     AH = 29h
  2747.     BX = offset into control block at which to start writing
  2748.     CX = number of bytes to write
  2749.     DX = segment/selector of control block obtained via AH=26h or AH=27h
  2750.     DS:SI -> buffer containing data to be written
  2751. Return: CF clear if successful
  2752.     CF set on errro
  2753.         AX = error code (see also #1020 at INT 21/AH=59h/BX=0000h)
  2754.         05h access denied due to an invalid segment/selector
  2755. Note:     this function performs no bounds checking
  2756. Program: PC-MOS/386 is a multitasking/multiuser MS-DOS-compatible operating
  2757.       system by The Software Link, Inc.
  2758. SeeAlso: AH=26h,AH=27h,AH=28h,AH=2Ah
  2759. --------O-D42A-------------------------------
  2760. INT D4 - PC-MOS/386 v5.01 - SWAP CONTROL BLOCK DATA OF SCB OR TCB
  2761.     AH = 2Ah
  2762.     BX = offset into control block at which to start swap
  2763.     CX = number of bytes to swap
  2764.     DX = segment/selector of control block obtained via AH=26h or AH=27h
  2765.     DS:SI -> buffer containing new data and to receive current data
  2766. Return: CF clear if successful
  2767.     CF set on error
  2768.         AX = error code (see also #1020 at INT 21/AH=59h/BX=0000h)
  2769.         05h access denied due to an invalid segment/selector
  2770. Note:    the interrupts are disabled during the swap to prevent corruption
  2771. SeeAlso: AH=26h,AH=27h,AH=28h,AH=29h
  2772. --------O-D42C-------------------------------
  2773. INT D4 - PC-MOS/386 v5.01 - GET/SET SPOOLER PARAMETERS
  2774.     AH = 2Ch
  2775.     AL = function
  2776.         00h set spooler timeout
  2777.         CX = timout value in seconds
  2778.         01h get spooler timeout
  2779.         Return: CX = current timeout in seconds
  2780.         02h get spooler parameters
  2781.         Return: CH = priority (00h-09h)
  2782.             CL = disposition (d, h, i, n, s)
  2783.             SI = class (a - z)
  2784.         03h set spooler parameters
  2785.         CH = priority (00h-09h)
  2786.         CL = disposition (d, h, i, n, s)
  2787.         SI = class (a - z)
  2788.         BX = task ID (FFFFh for current task)
  2789.         DX = LPT number
  2790. Return: CF clear if successful
  2791.     CF set on error
  2792.         AX = error code (see #1020 at INT 21/AH=59h/BX=0000h)
  2793. SeeAlso: AH=00h,AH=02h,AH=03h
  2794. --------O-D42D-------------------------------
  2795. INT D4 - PC-MOS/386 v5.01 - GET MAXIMUM TASK SIZE
  2796.     AH = 2Dh
  2797. Return: DX = maximum task size in paragraphs
  2798.     BX = start address of task space
  2799. Program: PC-MOS/386 is a multitasking/multiuser MS-DOS-compatible operating
  2800.       system by The Software Link, Inc.
  2801. SeeAlso: AH=1Fh,AH=22h
  2802. --------r-D5---------------------------------
  2803. INT D5 - IBM ROM BASIC - used while in interpreter
  2804. Notes:    called by ROM BASIC, but pointed at IRET by BASIC.COM/BASICA.COM
  2805.     BASIC.COM/BASICA.COM do not restore vector on termination
  2806. SeeAlso: INT 80"BASIC",INT D4"BASIC",INT D6"BASIC"
  2807. --------r-D5---------------------------------
  2808. INT D5 - STSC APL*PLUS/PC - MAY BE USED IN FUTURE RELEASES
  2809. --------r-D6---------------------------------
  2810. INT D6 - IBM ROM BASIC - used while in interpreter
  2811. Notes:    called by ROM BASIC, but pointed at IRET by BASIC.COM/BASICA.COM
  2812.     BASIC.COM/BASICA.COM do not restore vector on termination
  2813. SeeAlso: INT 80"BASIC",INT D5"BASIC",INT D7"BASIC"
  2814. --------r-D6---------------------------------
  2815. INT D6 - STSC APL*PLUS/PC - MAY BE USED IN FUTURE RELEASES
  2816. --------r-D7---------------------------------
  2817. INT D7 - IBM ROM BASIC - used while in interpreter
  2818. Notes:    called by ROM BASIC, but pointed at IRET by BASIC.COM/BASICA.COM
  2819.     BASIC.COM/BASICA.COM do not restore vector on termination
  2820. SeeAlso: INT 80"BASIC",INT D6"BASIC",INT D8"BASIC"
  2821. --------r-D7---------------------------------
  2822. INT D7 - STSC APL*PLUS/PC - MAY BE USED IN FUTURE RELEASES
  2823. --------r-D8---------------------------------
  2824. INT D8 - IBM ROM BASIC - used while in interpreter
  2825. Notes:    called by ROM BASIC
  2826.     BASIC.COM/BASICA.COM do not restore vector on termination
  2827. SeeAlso: INT 80"BASIC",INT D7"BASIC",INT D9"BASIC"
  2828. --------r-D8---------------------------------
  2829. INT D8 - STSC APL*PLUS/PC - MAY BE USED IN FUTURE RELEASES
  2830. --------H-D8---------------------------------
  2831. INT D8 - Screen Thief v1.00 - RELOCATED IRQ0
  2832. Range:    INT 78h to INT E0h, selected by commandline switch
  2833. Note:    Screen Thief relocates IRQs 0 through 7 to INT D8 to INT DF by default,
  2834.       but may be directed via a commandline switch to use any range
  2835.       starting at a multiple of 8 between 78h and E0h
  2836. SeeAlso: INT 08"IRQ0",INT 2D/AL=10h"Screen Thief",INT 50"DESQview"
  2837. SeeAlso: INT D9"Screen Thief"
  2838. --------r-D9---------------------------------
  2839. INT D9 - IBM ROM BASIC - used while in interpreter
  2840. Notes:    called by ROM BASIC, but pointed at IRET by BASIC.COM/BASICA.COM
  2841.     BASIC.COM/BASICA.COM do not restore vector on termination
  2842. SeeAlso: INT 80"BASIC",INT D8"BASIC",INT DA"BASIC"
  2843. --------r-D9---------------------------------
  2844. INT D9 - STSC APL*PLUS/PC - MAY BE USED IN FUTURE RELEASES
  2845. --------H-D9---------------------------------
  2846. INT D9 - Screen Thief v1.00 - RELOCATED IRQ1
  2847. Range:    INT 79h to INT E1h, selected by commandline switch
  2848. Note:    (see INT D8"Screen Thief")
  2849. SeeAlso: INT 09"IRQ1",INT D8"Screen Thief",INT DA"Screen Thief"
  2850. --------r-DA---------------------------------
  2851. INT DA - IBM ROM BASIC - used while in interpreter
  2852. Notes:    called by ROM BASIC, but pointed at IRET by BASIC.COM/BASICA.COM
  2853.     BASIC.COM/BASICA.COM do not restore vector on termination
  2854. SeeAlso: INT 80"BASIC",INT D9"BASIC",INT DB"BASIC"
  2855. --------r-DA---------------------------------
  2856. INT DA - STSC APL*PLUS/PC - MAY BE USED IN FUTURE RELEASES
  2857. --------H-DA---------------------------------
  2858. INT DA - Screen Thief v1.00 - RELOCATED IRQ2
  2859. Range:    INT 7Ah to INT E2h, selected by commandline switch
  2860. Note:    (see INT D8"Screen Thief")
  2861. SeeAlso: INT 0A"IRQ2",INT D9"Screen Thief",INT DB"Screen Thief"
  2862. --------r-DB---------------------------------
  2863. INT DB - IBM ROM BASIC - used while in interpreter
  2864. Notes:    called by ROM BASIC
  2865.     BASIC.COM/BASICA.COM do not restore vector on termination
  2866. SeeAlso: INT 80"BASIC",INT DA"BASIC",INT DC"BASIC"
  2867. --------r-DB---------------------------------
  2868. INT DB - STSC APL*PLUS/PC - MAY BE USED IN FUTURE RELEASES
  2869. --------H-DB---------------------------------
  2870. INT DB - Screen Thief v1.00 - RELOCATED IRQ3
  2871. Range:    INT 7Bh to INT E3h, selected by commandline switch
  2872. Note:    (see INT D8"Screen Thief")
  2873. SeeAlso: INT 0B"IRQ3",INT DA"Screen Thief",INT DC"Screen Thief"
  2874. --------u-DC---------------------------------
  2875. INT DC - PC/370 v4.1- - API
  2876. SeeAlso: INT 60"PC/370"
  2877. --------r-DC---------------------------------
  2878. INT DC - IBM ROM BASIC - used while in interpreter
  2879. Notes:    called by ROM BASIC
  2880.     BASIC.COM/BASICA.COM do not restore vector on termination
  2881. SeeAlso: INT 80"BASIC",INT DB"BASIC",INT DD"BASIC"
  2882. --------r-DC---------------------------------
  2883. INT DC - STSC APL*PLUS/PC - MAY BE USED IN FUTURE RELEASES
  2884. --------H-DC---------------------------------
  2885. INT DC - Screen Thief v1.00 - RELOCATED IRQ4
  2886. Range:    INT 7Ch to INT E4h, selected by commandline switch
  2887. Note:    (see INT D8"Screen Thief")
  2888. SeeAlso: INT 0C"IRQ4",INT DB"Screen Thief",INT DD"Screen Thief"
  2889. --------r-DD---------------------------------
  2890. INT DD - IBM ROM BASIC - used while in interpreter
  2891. Notes:    called by ROM BASIC
  2892.     BASIC.COM/BASICA.COM do not restore vector on termination
  2893. SeeAlso: INT 80"BASIC",INT DC"BASIC",INT DE"BASIC"
  2894. --------r-DD---------------------------------
  2895. INT DD - STSC APL*PLUS/PC v9.0 - PLACE KEYSTROKE EVENTS IN INPUT BUFFER
  2896.     BX = where to place keystrokes
  2897.         FFFFh insert before current buffer contents
  2898.         0000h replace current contents
  2899.         0001h insert after current contents
  2900.     CX = number of keystroke events to insert
  2901.     ES:SI -> data to be placed into buffer (list of WORD key codes)
  2902.         4000h + N = normal ASCII keystroke N (N = 00h to FFh)
  2903.         4100h + N = extended ASCII keystroke N (N = 03h to 84h)
  2904. Return: nothing
  2905. SeeAlso: INT 16/AH=05h
  2906. --------H-DD---------------------------------
  2907. INT DD - Screen Thief v1.00 - RELOCATED IRQ5
  2908. Range:    INT 7Dh to INT E5h, selected by commandline switch
  2909. Note:    (see INT D8"Screen Thief")
  2910. SeeAlso: INT 0D"IRQ5",INT DC"Screen Thief",INT DE"Screen Thief"
  2911. --------r-DE---------------------------------
  2912. INT DE - IBM ROM BASIC - used while in interpreter
  2913. Notes:    called by ROM BASIC
  2914.     BASIC.COM/BASICA.COM do not restore vector on termination
  2915. SeeAlso: INT 80"BASIC",INT DD"BASIC",INT DF"BASIC"
  2916. --------r-DE---------------------------------
  2917. INT DE - APL*PLUS/PC - ???
  2918. Note:    appears to be the same as INT 16
  2919. --------H-DE---------------------------------
  2920. INT DE - Screen Thief v1.00 - RELOCATED IRQ6
  2921. Range:    INT 7Eh to INT E6h, selected by commandline switch
  2922. Note:    (see INT D8"Screen Thief")
  2923. SeeAlso: INT 0E"IRQ6",INT DD"Screen Thief",INT DF"Screen Thief"
  2924. --------b-DF---------------------------------
  2925. INT DF - Victor 9000/Sirius 1 - SuperBIOS
  2926. SeeAlso: INT 21/AH=EAh"NetWare"
  2927. --------r-DF---------------------------------
  2928. INT DF - IBM ROM BASIC - used while in interpreter
  2929. Notes:    called by ROM BASIC
  2930.     BASIC.COM/BASICA.COM do not restore vector on termination
  2931. SeeAlso: INT 80"BASIC",INT DE"BASIC",INT E0"BASIC"
  2932. --------r-DF---------------------------------
  2933. INT DF - APL*PLUS/PC - SAME AS INT 10
  2934. SeeAlso: INT 10/AH=00h,INT 10/AH=0Eh
  2935. --------H-DF---------------------------------
  2936. INT DF - Screen Thief v1.00 - RELOCATED IRQ7
  2937. Range:    INT 7Fh to INT E7h, selected by commandline switch
  2938. Note:    (see INT D8"Screen Thief")
  2939. SeeAlso: INT 0F"IRQ7",INT DE"Screen Thief"
  2940. --------r-E0---------------------------------
  2941. INT E0 - IBM ROM BASIC - used while in interpreter
  2942. Notes:    called by ROM BASIC
  2943.     BASIC.COM/BASICA.COM do not restore vector on termination
  2944. SeeAlso: INT 80"BASIC",INT DF"BASIC",INT E1"BASIC"
  2945. --------r-E0---------------------------------
  2946. INT E0 - APL*PLUS/PC - RESTIME HIGH-RESOLUTION TIMER FOR QUAD MF FUNCTION
  2947. SeeAlso: INT CF"APL"
  2948. --------v-E0---------------------------------
  2949. INT E0 - VIRUS - "Micro-128" - ???
  2950. Note:    Micro-128 also overwrites the upper half of the interrupt table
  2951. SeeAlso: INT 9E"VIRUS",INT F1"VIRUS"
  2952. ----------E0---------------------------------
  2953. INT E0 - DeskMate (Tandy) - DESK EXECUTIVE API
  2954.     AX = function code (numerous)
  2955.     parameters passed in BX, DX, ES, DI, and/or BP
  2956. Return: AX = return from function
  2957. Program: DeskMate is a proprietary GUI from Tandy distributed with several
  2958.       models of the Tandy 1000's, 2500's, 3000's, and laptops.  Retail
  2959.       and runtime versions also exist.  Some Tandy's are designed to
  2960.       boot directly into DeskMate.
  2961. SeeAlso: INT 15/AX=7002h,INT E1"DeskMate"
  2962. --------O-E0---------------------------------
  2963. INT E0 - CP/M-86, Concurrent CP/M, DR Multiuser DOS - FUNCTION CALLS
  2964.     CL = function number (see #3268,#3269)
  2965.     DS,DX = parameters
  2966. Return: as appropriate for function
  2967.     CX is often the error code (see #3270)
  2968. Notes:    several functions are covered in more detail in following entries
  2969.     most of these calls are also supported by Digital Research's DOS Plus
  2970.       v2.1; the unsupported functions are 26h,29h-2Bh,3Ah,3Dh-62h,71h-8Ch,
  2971.       90h-92h,94h-97h,9Bh-ABh, and AEh-FFh
  2972. SeeAlso: INT 21/AX=4459h,INT 21/AH=E0h"DOS Plus"
  2973.  
  2974. (Table 3268)
  2975. Values for CP/M-86,DR Multiuser DOS function number:
  2976.  00h    terminate calling process (see also INT 21/AH=00h)
  2977.  01h    read a character
  2978.  02h    write character to default console (see also INT 21/AH=02h)
  2979.  03h    read character from default AUX (see also INT 21/AH=03h)
  2980.  04h    write character to default AUX (see also INT 21/AH=04h)
  2981.  05h    write character to default list device (see also INT 21/AH=05h)
  2982.  06h    perform raw I/O on default console (see also INT 21/AH=06h)
  2983.  07h    return default AUX input status
  2984.  08h    return default AUX output status
  2985.  09h    write string to default console (see also INT 21/AH=09h)
  2986.  0Ah    read string from default console (see also INT 21/AH=0Ah)
  2987.  0Bh    return default console input status (see also INT 21/AH=0Bh)
  2988.  0Ch    get BDOS release ID
  2989.  0Dh    reset all disk drives (see also INT 21/AH=0Dh)
  2990.  0Eh    set default drive (see also INT 21/AH=0Eh)
  2991.  0Fh    open file via FCB (see also INT 21/AH=0Fh,#0693)
  2992.  10h    close file via FCB (see also INT 21/AH=10h)
  2993.  11h    search for first matching file with FCB (see also INT 21/AH=11h)
  2994.  12h    search for next matching file with FCB (see also INT 21/AH=12h)
  2995.  13h    delete file via FCB (see also INT 21/AH=13h)
  2996.  14h    sequential read via FCB (see also INT 21/AH=14h)
  2997.  15h    sequential write via FCB (see also INT 21/AH=15h)
  2998.  16h    create file via FCB (see also INT 21/AH=16h)
  2999.  17h    rename file via FCB (see also INT 21/AH=17h)
  3000.  18h    get bit map of logged drives
  3001.  19h    get default drive (see also INT 21/AH=19h)
  3002.  1Ah    set DMA address offset
  3003.  1Bh    get default disk allocation vector (see also INT 21/AH=1Bh)
  3004.  1Ch    set default drive to read-only
  3005.  1Dh    get bit map of read-only drives
  3006.  1Eh    set file attributes via FCB (see also INT 21/AX=4301h)
  3007.  1Fh    get address of disk parameter block (see also INT 21/AH=1Fh)
  3008.  20h    get/set default user number
  3009.  21h    read random record via FCB (see also INT 21/AH=21h)
  3010.  22h    write random record via FCB (see also INT 21/AH=22h)
  3011.  23h    compute file size with FCB (see also INT 21/AH=23h)
  3012.  24h    get FCB random record number (see also INT 21/AH=24h)
  3013.  25h    reset specified drives
  3014.  26h    access specified drives (not in DR DOS Plus v2.1)
  3015.  27h    free specified drives
  3016.  28h    write random with FCB, zero fill (see also INT 21/AH=28h)
  3017.  2Ah    lock records in FCB file (see also INT 21/AH=5Ch)
  3018.  2Bh    unlock records in FCB file (see also INT 21/AH=5Ch)
  3019.  2Ch    set BDOS multisector count
  3020.  2Dh    set BDOS error mode
  3021.  2Eh    get free space on disk
  3022.  2Fh    load, initialize, and jump to process (see also INT 21/AH=4Bh)
  3023.  30h    flush write-deferred buffers
  3024.  31h    get/set system variable (DOS Plus v2.1)
  3025.  32h    call BIOS (XIOS) character routine (see #3269)
  3026.  33h    set DMA address segment
  3027.  34h    get DMA buffer address
  3028.  35h    CP/M-86 allocate maximum memory
  3029.  36h    allocate maximum memory at specified segment
  3030.  37h    CP/M-86 allocate memory segment (see also INT 21/AH=48h)
  3031.  38h    allocate memory at specified segment
  3032.  39h    CP/M-86 free specified memory segment (see also INT 21/AH=49h)
  3033.  3Ah    CP/M-86 free all memory (not in DOS Plus v2.1)
  3034.  3Bh    load .CMD file into memory
  3035.  3Ch    (DOS Plus v2.1) call RSX program
  3036.  40h    (DR-NET) log on a server
  3037.  41h    (DR-NET) log off a server
  3038.  42h    (DR-NET) send a message
  3039.  43h    (DR-NET) receive a message
  3040.  44h    (DR-NET) get network status
  3041.  45h    (DR-NET) get requestor configuration table
  3042.  46h    (DR-NET) set compatibility attributes
  3043.  47h    (DR-NET) get server configuration table
  3044.  48h    (DR-NET) set network error mode
  3045.  49h    (DR-NET) attach network
  3046.  4Ah    (DR-NET) detach network
  3047.  4Bh    (DR-NET) set default password
  3048.  4Ch    (DR-NET) get-set long timeout
  3049.  4Dh    (DR-NET) get parameter table
  3050.  50h    (DR-NET) get network information
  3051.  53h    get current time (see also INT 21/AH=2Ch)
  3052.  54h    set current time (see also INT 21/AH=2Dh)
  3053.  55h    get binary system date (see also INT 21/AH=2Ah)
  3054.  56h    set system date (see also INT 21/AH=2Bh"DATE")
  3055.  57h    allocate system flag
  3056.  58h    deallocate system flag
  3057.  59h    reserve memory in global area
  3058.  5Ah    lock physical drive
  3059.  5Bh    unlock physical drive
  3060.  5Ch    search path for executable file
  3061.  5Dh    load and execute command (see also INT 21/AH=4Bh)
  3062.  5Eh    get/set process exit code
  3063.  5Fh    set country information
  3064.  60h    get country information
  3065.  63h    truncate FCB file (see also INT 21/AH=28h)
  3066.  64h    create/update directory label
  3067.  65h    get directory label
  3068.  66h    get FCB date stamp and password mode
  3069.  67h    write extended FCB
  3070.  68h    set system date and time
  3071.  69h    get system date and time in binary
  3072.  6Ah    establish password for file access
  3073.  6Bh    get OS serial number
  3074.  6Ch    (DOS Plus v2.1) get/set program return code
  3075.  6Dh    get/set console mode
  3076.  6Eh    get/set string delimiter
  3077.  6Fh    write block to default console
  3078.  70h    write block to default list device
  3079.  71h    execute DOS-compatible function
  3080.  74h    set FCB time and date stamps
  3081.  80h    allocate memory
  3082.  82h    deallocate memory
  3083.  83h    poll I/O device
  3084.  84h    wait on system flag
  3085.  85h    set system flag
  3086.  86h    create message queue
  3087.  87h    open message queue
  3088.  88h    delete message queue
  3089.  89h    read from message queue
  3090.  8Ah    conditionally read from message queue
  3091.  8Bh    write to message queue
  3092.  8Ch    conditionally write to message queue
  3093.  8Dh    delay calling process
  3094.  8Eh    call process dispatcher (yield CPU)
  3095.  8Fh    terminate calling process (same as function 00h)
  3096.  90h    create a process
  3097.  91h    set calling process' priority
  3098.  92h    attach to default console
  3099.  93h    detach from default console
  3100.  95h    assign default console to process
  3101.  96h    interpret and execute commandline
  3102.  97h    resident procedure library
  3103.  98h    parse ASCII string into FCB (see also INT 21/AH=29h)
  3104.  99h    return default console
  3105.  9Ah    get address of system data (SYSDAT)
  3106.  9Bh    get system time and date
  3107.  9Ch    return calling process' descriptor
  3108.  9Dh    terminate process by name or PD address
  3109.  9Eh    attach to default list device
  3110.  9Fh    detach from default list device
  3111.  A0h    select default list device
  3112.  A1h    conditionally attach to default list device
  3113.  A2h    conditionally attach to default console
  3114.  A3h    get OS version number
  3115.  A4h    get default list device
  3116.  A5h    attach to default AUX
  3117.  A6h    detach from default AUX
  3118.  A7h    conditionally attach to default AUX
  3119.  A8h    set default AUX
  3120.  A9h    return default AUX
  3121.  ACh    read block from default AUX
  3122.  ADh    (DOS Plus v2.1) write block to default AUX
  3123.  B0h    configure default AUX
  3124.  B1h    get/set device control parameters
  3125.  B2h    send Break through default AUX
  3126.  B3h    allocate physical memory
  3127.  B4h    free physical memory
  3128.  B5h    map physical memory
  3129.  B6h    nondestructive message queue read
  3130.  B7h    timed wait on system flag
  3131.  B8h    get/set I/O port mapping
  3132.  B9h    set list device timeout
  3133.  BAh    set AUX timeout value
  3134.  BBh    execute XIOS service
  3135.  BDh    (DR Multiuser DOS) delay
  3136.  FFh    return 80386 to native mode
  3137.  
  3138. (Table 3269)
  3139. Values for DOS Plus v2.1 XIOS functions:
  3140.  00h    terminate program
  3141.  01h    ???
  3142.  02h    check for console input status
  3143.  03h    read character from console
  3144.  04h    write character to console
  3145.  05h    write character to list device
  3146.  06h    write character to auxiliary device
  3147.  07h    read character from auxiliary device
  3148.  0Fh    get list device status
  3149.  10h-14h reserved
  3150.  15h    device initialization
  3151.  16h    check console output status
  3152.  17h-7Fh reserved
  3153. ---BBC Acorn---
  3154.  80h    get XIOS version
  3155.  81h    get Tube semaphore
  3156.  82h    release Tube semaphore
  3157.  83h    select text/graphics
  3158.  84h    update B&W graphics rectangle
  3159.  85h    update color graphics rectangle
  3160.  86h    get/release/update mouse
  3161.  87h    get system error info
  3162.  88h    entry in CLOCK called by WatchDog RSP
  3163.  89h    BBC OSBYTE function
  3164.  8Ah    BBC OSWORD function
  3165.  
  3166. (Table 3270)
  3167. Values for DR Multiuser DOS Error Return Code:
  3168.  00h    no error
  3169.  01h    system call not implemented
  3170.  02h    illegal system call number
  3171.  03h    cannot find memory
  3172.  04h    illegal flag number
  3173.  05h    flag overrun
  3174.  06h    flag underrun
  3175.  07h    no unused Queue Descriptors
  3176.  08h    no free queue buffer
  3177.  09h    cannot find queue
  3178.  0Ah    queue in use
  3179.  0Ch    no free Process Descriptors
  3180.  0Dh    no queue access
  3181.  0Eh    empty queue
  3182.  0Fh    full queue
  3183.  10h    CLI queue missing
  3184.  11h    no 8087 in system
  3185.  12h    no unused Memory Descriptors
  3186.  13h    illegal console number
  3187.  14h    no Process Descriptor match
  3188.  15h    no console match
  3189.  16h    no CLI process
  3190.  17h    illegal disk number
  3191.  18h    illegal filename
  3192.  19h    illegal filetype
  3193.  1Ah    character not ready
  3194.  1Bh    illegal Memory Descriptor
  3195.  1Ch    bad return from BDOS load
  3196.  1Dh    bad return from BDOS read
  3197.  1Eh    bad return from BDOS open
  3198.  1Fh    null command
  3199.  20h    not owner of resource
  3200.  21h    no CSEG in load file
  3201.  22h    process Descriptor exists on Thread Root
  3202.  23h    could not terminate process
  3203.  24h    cannot attach to process
  3204.  25h    illegal list device number
  3205.  26h    illegal password
  3206.  28h    external termination occurred
  3207.  29h    fixup error upon load
  3208.  2Ah    flag set ignored
  3209.  2Bh    illegal auxilliary device number
  3210. --------O-E0----CL03-------------------------
  3211. INT E0 - DR Multiuser DOS - "A_READ" - READ CHARACTER FROM AUX DEVICE
  3212.     CL = 03h
  3213. Return: AL = ASCII character
  3214. Notes:    A_READ reads the next 8-bit character from the logical auxilliary
  3215.       input device (AUXn:); control is not returned to the calling
  3216.       process until a character has been read.
  3217.     if another process owns AUX, this call blocks until the device becomes
  3218.       available
  3219. SeeAlso: INT 21/AH=03h,INT E0/CL=04h,INT E0/CL=07h,INT E0/CL=A5h,INT E0/CL=ACh
  3220. --------O-E0----CL04-------------------------
  3221. INT E0 - DR Multiuser DOS - "A_WRITE" - WRITE CHARACTER TO AUX DEVICE
  3222.     CL = 04h
  3223.     DL = ASCII character
  3224. Return: nothing
  3225. Note:    if another process owns AUX, this call blocks until the device becomes
  3226.       available
  3227. SeeAlso: INT 21/AH=04h,INT E0/CL=03h,INT E0/CL=08h,INT E0/CL=A5h,INT E0/CL=ADh
  3228. --------O-E0----CL07-------------------------
  3229. INT E0 - DR Multiuser DOS - "A_STATIN" - GET INPUT STATUS OF AUX DEVICE
  3230.     CL = 07h
  3231. Return: AL = status
  3232.         00h not ready
  3233.         FFh character available
  3234. Desc:    determine whether the current AUX device has input available
  3235. SeeAlso: INT E0/CL=03h,INT E0/CL=08h
  3236. --------O-E0----CL08-------------------------
  3237. INT E0 - DR Multiuser DOS - "A_STATOUT" - GET OUTPUT STATUS OF AUX DEVICE
  3238.     CL = 08h
  3239. Return: AL = status
  3240.         00h not ready
  3241.         FFh ready for output
  3242. Desc:    determine whether the current AUX device is able to accept more output
  3243. SeeAlso: INT E0/CL=04h,INT E0/CL=07h
  3244. --------O-E0----CL59-------------------------
  3245. INT E0 - ConcCP/M,DR Multiuser DOS - "S_MEMORY" - RESERVE MEMORY IN GLOBAL AREA
  3246.     CL = 59h
  3247.     DX = size in bytes
  3248. Return: AX = status
  3249.         FFFFh failed
  3250.         other successful
  3251.         ES:BX -> reserved memory
  3252. --------O-E0----CL86-------------------------
  3253. INT E0 - ConcCP/M,DR Multiuser DOS - "Q_MAKE" - CREATE MESSAGE QUEUE
  3254.     CL = 86h
  3255.     DS:DX -> queue descriptor (see #3271)
  3256. Return: AX = status (0000h success, FFFFh failure)
  3257.     CX = error code (see #3270)
  3258. SeeAlso: INT E0/CL=87h
  3259.  
  3260. Format of DR Multiuser DOS queue descriptor:
  3261. Offset    Size    Description    (Table 3271)
  3262.  00h  2 WORDs    internal use, initialize to zeros
  3263.  04h    WORD    flags
  3264.  06h  8 BYTEs    queue name
  3265.  0Eh    WORD    length of message
  3266.  10h    WORD    number of messages
  3267.  12h  4 WORDs    internal use, initialize to zeros
  3268.  1Ah    WORD    offset in system area of buffer for messages
  3269. --------O-E0----CL87-------------------------
  3270. INT E0 - ConcCP/M,DR Multiuser DOS - "Q_OPEN" - OPEN MESSAGE QUEUE
  3271.     CL = 87h
  3272.     DS:DX -> queue parameter block (see #3272)
  3273. Return: AX = status (0000h success, FFFFh failure)
  3274.     CX = error code (see #3270)
  3275. SeeAlso: INT E0/CL=86h,INT E0/CL=89h
  3276.  
  3277. Format of DR Multiuser DOS queue parameter block:
  3278. Offset    Size    Description    (Table 3272)
  3279.  00h    WORD    internal use, initialize to zero
  3280.  02h    WORD    queue ID (set by INT E0/CL=87h)
  3281.  04h    WORD    internal use, initialize to zero
  3282.  06h    WORD    offset of queue message buffer
  3283.  08h  8 BYTEs    queue name
  3284. --------O-E0----CL89-------------------------
  3285. INT E0 - ConcCP/M,DR Multiuser DOS - "Q_READ" - READ MESSAGE QUEUE
  3286.     CL = 89h
  3287.     DS:DX -> queue parameter block (see #3272)
  3288. Return: AX = status (0000h success, FFFFh failure)
  3289.     CX = error code (see #3270)
  3290. SeeAlso: INT E0/CL=87h,INT E0/CL=8Ah,INT E0/CL=8Bh
  3291. --------O-E0----CL8A-------------------------
  3292. INT E0 - ConcCP/M,DR Multiuser DOS - "Q_CREAD" - CONDITIONALLY READ MSG QUEUE
  3293.     CL = 8Ah
  3294.     DS:DX -> queue parameter block (see #3272)
  3295. Return: AX = status (0000h success, FFFFh failure)
  3296.     CX = error code (see #3270)
  3297. SeeAlso: INT E0/CL=87h,INT E0/CL=89h,INT E0/CL=8Ch
  3298. --------O-E0----CL8B-------------------------
  3299. INT E0 - ConcCP/M,DR Multiuser DOS - "Q_WRITE" - WRITE MESSAGE QUEUE
  3300.     CL = 8Bh
  3301.     DS:DX -> queue parameter block (see #3272)
  3302. Return: AX = status (0000h success, FFFFh failure)
  3303.     CX = error code (see #3270)
  3304. SeeAlso: INT E0/CL=89h,INT E0/CL=8Ch
  3305. --------O-E0----CL8C-------------------------
  3306. INT E0 - ConcCP/M,DR Multiuser DOS - "Q_CWRITE" - CONDITIONALLY WRITE MSG QUEUE
  3307.     CL = 8Ch
  3308.     DS:DX -> queue parameter block (see #3272)
  3309. Return: AX = status (0000h success, FFFFh failure)
  3310.     CX = error code (see #3270)
  3311. SeeAlso: INT E0/CL=8Ah,INT E0/CL=8Bh
  3312. --------O-E0----CL8E-------------------------
  3313. INT E0 - ConcCP/M,DR Multiuser DOS - "P_DISPATCH" - CALL DISPATCHER
  3314.     CL = 8Eh
  3315.     DX = FFFFh (optional) to force dispatch
  3316. Return: nothing
  3317. Desc:    allow other processes of the same or higher priority to run if they
  3318.       are ready
  3319. Note:    if DX=FFFFh, a dispatch is forced even if no other process is ready
  3320. SeeAlso: INT E0/CL=91h
  3321. --------O-E0----CL91-------------------------
  3322. INT E0 - ConcCP/M,DR Multiuser DOS - "P_PRIORITY" - SET PROCESS PRIORITY
  3323.     CL = 91h
  3324.     DL = new priority (00h highest to FFh lowest)
  3325. Return: nothing
  3326. Note:    sets priority of calling process; transient processes are initialized
  3327.       to priority C8h
  3328. SeeAlso: INT E0/CL=8Eh
  3329. --------O-E0----CL93-------------------------
  3330. INT E0 - ConcCP/M,DR Multiuser DOS - "C_DETACH" - DETACH FROM DEFAULT CONSOLE
  3331.     CL = 93h
  3332. Return: AX = status
  3333.         0000h successfully detached
  3334.         FFFFh detach failed
  3335. SeeAlso: INT E0/CL=A6h
  3336. --------O-E0----CLA5-------------------------
  3337. INT E0 - DR Multiuser DOS - "A_ATTACH" - ATTACH AUX DEVICE
  3338.     CL = A5h
  3339. Return: nothing
  3340. Desc:    attaches the default auxiliary device to the calling process unless
  3341.       it is already attached to another process, in which case the call
  3342.       blocks until the device becomes available
  3343. Note:    this call should be used before attempting to read or write from
  3344.       the AUX device; however, the I/O calls internally call this function
  3345.       to ensure device ownership
  3346. SeeAlso: INT E0/CL=03h,INT E0/CL=04h,INT E0/CL=A6h,INT E0/CL=A7h,INT E0/CL=A8h
  3347. SeeAlso: INT E0/CL=ACh,INT E0/CL=ADh,INT E0/CL=B0h
  3348. --------O-E0----CLA6-------------------------
  3349. INT E0 - DR Multiuser DOS - "A_DETACH" - DETACH FROM AUX DEVICE
  3350.     CL = A6h
  3351. Return: AX = status
  3352.         0000h successfully detached
  3353.         FFFFh detach failed
  3354.     CX = error code
  3355. SeeAlso: INT E0/CL=93h,INT E0/CL=A5h,INT E0/CL=A7h
  3356. --------O-E0----CLA7-------------------------
  3357. INT E0 - DR Multiuser DOS - "A_CATTACH" - CONDITIONALLY ATTACH TO AUX DEVICE
  3358.     CL = A7h
  3359. Return: AX = status
  3360.         0000h attached
  3361.         FFFFh unable to attach
  3362. Desc:    attaches the default auxiliary device to the calling process if it is
  3363.       available
  3364. Note:    does not block if the device is already in use
  3365. SeeAlso: INT E0/CL=A5h,INT E0/CL=A6h,INT E0/CL=A8h,INT E0/CL=B0h
  3366. --------O-E0----CLA8-------------------------
  3367. INT E0 - DR Multiuser DOS - "A_SET" - SET DEFAULT AUX DEVICE NUMBER
  3368.     CL = A8h
  3369.     DL = auxiliary device number
  3370. Return: AX = status
  3371.         0000h successful
  3372.         FFFFh failed
  3373.     CX = error code
  3374. Desc:    specify which physical device will become AUX
  3375. SeeAlso: INT E0/CL=A5h,INT E0/CL=A9h
  3376. --------O-E0----CLA9-------------------------
  3377. INT E0 - DR Multiuser DOS - "A_GET" - GET DEFAULT AUX DEVICE NUMBER
  3378.     CL = A9h
  3379. Return: AL = current default auxiliary device number
  3380. Desc:    determine which physical device is currently AUX
  3381. SeeAlso: INT E0/CL=A8h
  3382. --------O-E0----CLAC-------------------------
  3383. INT E0 - DR Multiuser DOS - "A_READBLK" - READ STRING FROM AUX DEVICE
  3384.     CL = ACh
  3385.     DS:DX -> character control block (CHCB) (see #3273)
  3386. Return: AX = number of characters read
  3387. Desc:    read characters from the default auxiliary (AUXn:) device into a buffer
  3388.       until the buffer is full or the device is no longer ready
  3389. Notes:    if the device is initially not ready, blocks until at least one
  3390.       character has been read
  3391.     if another process owns AUX, this call blocks until the device becomes
  3392.       available
  3393. SeeAlso: INT E0/CL=03h,INT E0/CL=A5h,INT E0/CL=ADh
  3394.  
  3395. Format of DR Multiuser DOS character control block (CHCB):
  3396. Offset    Size    Description    (Table 3273)
  3397.  00h    DWORD    pointer to character buffer
  3398.  04h    WORD    length of character buffer
  3399. --------O-E0----CLAD-------------------------
  3400. INT E0 - DR Multiuser DOS - "A_WRITEBLK" - WRITE STRING TO AUX DEVICE
  3401.     CL = ADh
  3402.     DS:DX -> character control block (see #3273)
  3403. Return: AX = number of characters written
  3404. Note:    does not return until at least one character has been written
  3405. SeeAlso: INT E0/CL=04h,INT E0/CL=A5h,INT E0/CL=ACh
  3406. --------O-E0----CLB0-------------------------
  3407. INT E0 - DR Multiuser DOS - "A_CONFIG" - GET/SET AUX DEVICE PARAMETERS
  3408.     CL = B0h
  3409.     DX:DX -> AUX device parameter block (see #3274)
  3410. Return: AX = status
  3411.         0000h successful
  3412.         parameter block updated
  3413.         FFFFh failed
  3414.         CX = error code
  3415. SeeAlso: INT E0/CL=A5h,INT E0/CL=B1h
  3416.  
  3417. Format of DR Multiuser DOS AUX device parameter block:
  3418. Offset    Size    Description    (Table 3274)
  3419.  00h    BYTE    function (00h get, 01h set)
  3420.  01h    BYTE    baud rate (see #3276) FFh = don't change/unknown
  3421.  02h    BYTE    parity (see #3275)
  3422.  03h    BYTE    stop bits (00h one, 01h 1.5, 02h two, FFh unknown/don't change)
  3423.  04h    BYTE    data bits (05h-08h or FFh unknown/don't change)
  3424.  05h    BYTE    handshake (00h none, 01h DTS/DSR, 02h RTS/CTS, 04h XON/XOFF,
  3425.         FFh unknown/don't change)
  3426.  06h    BYTE    XON character, FFh unknown/don't change
  3427.  07h    BYTE    XOFF character, FFh unknown/don't change
  3428.  
  3429. (Table 3275)
  3430. Values for DR Multiuser DOS AUX parity:
  3431.  00h    none
  3432.  01h    odd
  3433.  02h    none
  3434.  03h    even
  3435.  04h    stick parity bit
  3436.  FFh    don't change/unknown
  3437. SeeAlso: #3274,#3276
  3438.  
  3439. (Table 3276)
  3440. Values for DR Multiuser DOS AUX baud rate:
  3441.  00h    50 baud
  3442.  01h    62.5 baud
  3443.  02h    75 baud
  3444.  03h    110 baud
  3445.  04h    134.5 baud
  3446.  05h    150 baud
  3447.  06h    200 baud
  3448.  07h    300 baud
  3449.  08h    600 baud
  3450.  09h    1200 baud
  3451.  0Ah    1800 baud
  3452.  0Bh    2000 baud
  3453.  0Ch    2400 baud
  3454.  0Dh    3600 baud
  3455.  0Eh    4800 baud
  3456.  0Fh    7200 baud
  3457.  10h    9600 baud
  3458.  11h    19200 baud
  3459.  12h    38400 baud
  3460.  13h    56000 baud
  3461.  14h    76800 baud
  3462.  15h    115200 baud
  3463. SeeAlso: #3274,#3275
  3464. --------O-E0----CLB1-------------------------
  3465. INT E0 - DR Multiuser DOS - "A_CONTROL" - GET/SET AUX CONTROL PARAMETERS
  3466.     CL = B1h
  3467.     DS:DX -> AUX device control block (see #3277)
  3468. Return: AX = status
  3469.         0000h successful
  3470.         control block updated
  3471.         FFFFh failed
  3472.         CX = error code
  3473. SeeAlso: INT E0/CL=B0h,INT E0/CL=B2h
  3474.  
  3475. Format of DR Multiuser DOS AUX device control block:
  3476. Offset    Size    Description    (Table 3277)
  3477.  00h    BYTE    function (00h get, 01h set)
  3478.  01h    BYTE    DTR state (00h low, 01h high, FFh unknown/don't change)
  3479.  02h    BYTE    RTS state (00h low, 01h high, FFh unknown/don't change)
  3480.  03h    BYTE    DSR state (00h low, 01h high, FFh unknown/don't change)
  3481.  04h    BYTE    CTS state (00h low, 01h high, FFh unknown/don't change)
  3482.  05h    BYTE    DCD state (00h low, 01h high, FFh unknown/don't change)
  3483.  06h    BYTE    RI state (00h inactive, 01h active, FFh unknown/don't change)
  3484. --------O-E0----CLB2-------------------------
  3485. INT E0 - DR Multiuser DOS - "A_BREAK" - SEND BREAK TO AUX DEVICE
  3486.     CL = B2h
  3487.     DX = duration of break in system ticks (0001h-FFFFh)
  3488. Return: AX = status
  3489.         0000h successful
  3490.         break signal completed
  3491.         FFFFh failed
  3492.         CX = error code
  3493. Note:    if the AUX device is currently owned by another process, this call will
  3494.       block until the device becomes available
  3495. SeeAlso: INT E0/CL=A5h,INT E0/CL=B1h
  3496. --------O-E0----CLBD-------------------------
  3497. INT E0 - DR Multiuser DOS - "P_DELAY" - DELAY EXECUTION
  3498.     CL = BDh
  3499.     DX = delay in system ticks
  3500. Return: after the delay elapses
  3501. Notes:    the length of a system tick is installation-dependent (typically
  3502.       1/50 or 1/60 second); the length may be determined by reading the
  3503.       TICKSPERSEC value from the system data segment
  3504.     the actual delay before the process is rescheduled to run may be up to
  3505.       one tick longer than requested; the delay between rescheduling and
  3506.       actual execution cannot be predicted if higher-priority processes
  3507.       are awaiting a turn at the CPU
  3508. SeeAlso: INT 15/AH=86h,INT 1A/AX=FF01h,INT 2F/AX=1224h,INT 62/AX=0096h
  3509. --------g-E00000-----------------------------
  3510. INT E0 - PCROBOTS v1.41 - "SWAPTASK" - END CURRENT ROBOT'S TURN
  3511.     AX = 0000h
  3512. Return: nothing
  3513. Program: PCROBOTS is P.D. Smith's adaptation of Tom Poindexter's CROBOTS, in
  3514.       which specially-written .COM or .EXE programs form robots battling
  3515.       each other in a user-defined arena
  3516. --------g-E00001-----------------------------
  3517. INT E0 - PCROBOTS v1.41 - "MOVEMENT" - START MOVING
  3518.     AX = 0001h
  3519.     BX = speed (0-maximum for robot)
  3520.     CX = direction (0-359 degrees)
  3521. Return: nothing
  3522. Notes:    the speed will change to the specified value at the maximum
  3523.       acceleration the robot is capable of; if the robot is already moving
  3524.       faster than its maximum maneuverability speed, it will not be able
  3525.       to change direction
  3526.     this call also terminates the current robot's turn
  3527. SeeAlso: AX=0000h,AX=0002h,AX=0003h
  3528. --------g-E00002-----------------------------
  3529. INT E0 - PCROBOTS v1.41 - "SCAN" - SCAN FOR OTHER ROBOTS IN THE GIVEN DIRECTION
  3530.     AX = 0002h
  3531.     BX = direction (0-359 degrees)
  3532.     CX = resolution (0-45 degrees)
  3533. Return: AX = status
  3534.         FFFFh if nothing detected
  3535.         else robot ID (0-19)
  3536.         BX = range to detected robot
  3537. Notes:    the scan searches within CX degrees to either side of the specified
  3538.       direction
  3539.     the scanner will see right through walls, but shells will not pass
  3540.       through walls
  3541.     this call also terminates the current robot's turn
  3542. SeeAlso: AX=0000h,AX=0001h,AX=0003h
  3543. --------g-E00003-----------------------------
  3544. INT E0 - PCROBOTS v1.41 - "SHOOT" - FIRE A SHELL AT ANOTHER ROBOT
  3545.     AX = 0003h
  3546.     BX = direction (0-359 degrees)
  3547.     CX = range (0-700)
  3548. Return: AX = status (0000h not fired, else ID of shell fired)
  3549. Notes:    up to seven shells may be in flight for a robot at one time; the cannon
  3550.       takes 50 ticks to reload
  3551.     this call also terminates the current robot's turn
  3552. SeeAlso: AX=0000h,AX=0001h,AX=0002h,AX=002Ch
  3553. --------g-E00010-----------------------------
  3554. INT E0 - PCROBOTS v1.41 - "GETXY" - GET ROBOT'S CURRENT POSITION
  3555.     AX = 0010h
  3556. Return: BX = current X coordinate (0-999)
  3557.     CX = current Y coordinate (0-999)
  3558. --------g-E00011-----------------------------
  3559. INT E0 - PCROBOTS v1.41 - "TRANSMIT" - SEND DATA TO ANOTHER ROBOT
  3560.     AX = 0011h
  3561.     BX = target robot ID
  3562.     CX = data to be sent
  3563. Return: AX = status (0000h data could not be sent, 0001h data sent)
  3564. Note:    this call costs one unit of battery power
  3565. --------g-E00012-----------------------------
  3566. INT E0 - PCROBOTS v1.41 - "RECEIVE" - GET DATA FROM OTHER ROBOTS
  3567.     AX = 0012h
  3568. Return: AX = status
  3569.         0000h no data available
  3570.         0001h data retrieved
  3571.         BX = sender's ID
  3572.         CX = data
  3573. Note:    each robot has a 20-word receive FIFO; if the FIFO is full, other
  3574.       robots will be unable to send more data until some is read
  3575. --------g-E00013-----------------------------
  3576. INT E0 - PCROBOTS v1.41 - "DAMAGE" - DETERMINE HOW MUCH DAMAGE SUSTAINED
  3577.     AX = 0013h
  3578. Return: BX = damage status
  3579. Note:    the initial value depends on configuration, but is typically 100; as
  3580.       the robot is damaged, it decreases
  3581. --------g-E00014-----------------------------
  3582. INT E0 - PCROBOTS v1.41 - "SPEED" - DETERMINE HOW FAST ROBOT IS MOVING
  3583.     AX = 0014h
  3584. Return: BX = current speed
  3585. --------g-E00015-----------------------------
  3586. INT E0 - PCROBOTS v1.41 - "BATTERY" - DETERMINE HOW MUCH BATTERY POWER LEFT
  3587.     AX = 0015h
  3588. Return: BX = current battery charge
  3589. Note:    the battery starts off with 1000 units of charge, and is constantly
  3590.       being charged by solar panels and constantly discharged by motion;
  3591.       the battery is charged at 4 units per turn and discharged at
  3592.       0.1*speed units per turn.
  3593. --------g-E00016-----------------------------
  3594. INT E0 - PCROBOTS v1.41 - "TICKS" - DETERMINE HOW LONG SINCE GAME STARTED
  3595.     AX = 0016h
  3596. Return: BX:CX = number of game ticks elapsed (not related to real time)
  3597. --------g-E00017-----------------------------
  3598. INT E0 - PCROBOTS v1.41 - "L_SIN" - GET SCALED SINE OF AN ANGLE
  3599.     AX = 0017h
  3600.     BX = angle (0-359 degrees)
  3601. Return: BX:CX = 100000*sine of angle
  3602. SeeAlso: AX=0018h,AX=0019h,AX=001Ah,AX=001Bh
  3603. --------g-E00018-----------------------------
  3604. INT E0 - PCROBOTS v1.41 - "L_COS" - GET SCALED COSINE OF AN ANGLE
  3605.     AX = 0018h
  3606.     BX = angle (0-359 degrees)
  3607. Return: BX:CX = 100000*cosine of angle
  3608. SeeAlso: AX=0017h,AX=0019h,AX=001Ah
  3609. --------g-E00019-----------------------------
  3610. INT E0 - PCROBOTS v1.41 - "L_TAN" - GET SCALED TANGENT OF AN ANGLE
  3611.     AX = 0019h
  3612.     BX = angle (0-359 degrees)
  3613. Return: BX:CX = 100000*tangent of angle
  3614. SeeAlso: AX=0017h,AX=0018h,AX=001Ah
  3615. --------g-E0001A-----------------------------
  3616. INT E0 - PCROBOTS v1.41 - "L_ATAN" - GET ANGLE GIVEN SCALED TANGENT
  3617.     AX = 001Ah
  3618.     BX:CX = 100000*tangent of an angle
  3619. Return: AX = angle (-90 to +90 degrees)
  3620. SeeAlso: AX=0017h,AX=0018h,AX=0019h
  3621. --------g-E0001B-----------------------------
  3622. INT E0 - PCROBOTS v1.41 - "SQRT" - DETERMINE SQUARE ROOT OF A NUMBER
  3623.     AX = 001Bh
  3624.     BX:CX = value
  3625. Return: BX:CX = square root
  3626. SeeAlso: AX=0017h
  3627. --------g-E0001C-----------------------------
  3628. INT E0 - PCROBOTS v1.41 - "SET_PATTERN" - SPECIFY ROBOT'S DISPLAY IMAGE
  3629.     AX = 001Ch
  3630.     BX:CX -> pattern array
  3631. Return: nothing
  3632. Note:    the pattern array consists of five bytes, the low five bits of each
  3633.       specifying the bit pattern for one line of the robot's screen display
  3634. --------g-E0001D-----------------------------
  3635. INT E0 - PCROBOTS v1.41 - "DEBUG_FLAG" - SET/CLEAR MARKERS NEXT TO ROBOT'S NAME
  3636.     AX = 001Dh
  3637.     BX = flag number (0 or 1)
  3638.     CX = new value (0 reset, 1 set)
  3639. Return: nothing
  3640. Program: PCROBOTS is P.D. Smith's adaptation of Tom Poindexter's CROBOTS, in
  3641.       which specially-written .COM or .EXE programs form robots battling
  3642.       each other in a user-defined arena
  3643. Note:    the two flag markers may be used for any purpose, typically for
  3644.       debugging to provide a visual display of progress
  3645. --------g-E0001E-----------------------------
  3646. INT E0 - PCROBOTS v1.41 - "BUY_ARMOUR" - BUY OR SELL ARMOR FOR ROBOT
  3647.     AX = 001Eh
  3648.     BX = number of armor units to buy (negative to sell)
  3649. Return: nothing
  3650. Note:    each armor unit is worth 50 battery units; the robot's armor rating
  3651.       will not go above its initial rating, so attempts to purchase more
  3652.       will waste battery units
  3653. SeeAlso: AX=001Fh
  3654. --------g-E0001F-----------------------------
  3655. INT E0 - PCROBOTS v1.41 - "BUY_SHELLS" - BUY ADDITIONAL CANNON SHELLS
  3656.     AX = 001Fh
  3657.     BX = number of shells to buy
  3658. Return: nothing
  3659. Note:    each shell costs ten battery units
  3660. SeeAlso: AX=001Eh,AX=0020h
  3661. --------g-E00020-----------------------------
  3662. INT E0 - PCROBOTS v1.41 - "SHELLS LEFT" - DETERMINE HOW MANY SHELLS ROBOT HAS
  3663.     AX = 0020h
  3664. Return: BX = number of shells remaining
  3665. SeeAlso: AX=001Fh
  3666. --------g-E00021-----------------------------
  3667. INT E0 - PCROBOTS v1.41 - "GET LOCAL MAP"
  3668.     AX = 0021h
  3669.     BX:CX -> 81-byte buffer for map (see #3278)
  3670. Return: buffer filled with 9x9 area of map centered on robot's position
  3671.  
  3672. (Table 3278)
  3673. Values for PCROBOTS map squares:
  3674.  2Eh '.' empty square
  3675.  44h 'D' damaging trap
  3676.  52h 'R' refueling point
  3677.  58h 'X' wall
  3678. --------g-E00022-----------------------------
  3679. INT E0 - PCROBOTS v1.41 - "INVISIBILITY" - CONTROL ROBOT'S INVISIBILITY DEVICE
  3680.     AX = 0022h
  3681.     BX = new state (0000h become visible, 0001h become invisible)
  3682. Return: nothing
  3683. Notes:    this function has no effect if the robot is not capable of invisibility
  3684.     the robot can only stay invisible for 100 turns, after which it will
  3685.       automatically become visible; it must also be remain visible for
  3686.       as many turns as it was invisible before it can turn invisible
  3687.       again
  3688. SeeAlso: AX=0024h,AX=0080h
  3689. --------g-E00023-----------------------------
  3690. INT E0 - PCROBOTS v1.41 - "GET_SHELL_STATUS" - FIND OUT WHAT HAPPENED TO SHELL
  3691.     AX = 0023h
  3692. Return: BX = status of last shell to land
  3693.         0000h missed completely
  3694.         0001h hit a wall
  3695.         0002h hit a robot within 50-square radius
  3696.         0003h hit a robot within 25-square radius
  3697.         0004h hit a robot within 5-square radius
  3698. --------g-E00024-----------------------------
  3699. INT E0 - PCROBOTS v1.41 - "IS_INVISIBLE" - DETERMINE WHETHER ROBOT IS INVISIBLE
  3700.     AX = 0024h
  3701. Return: BX = visibility (0000h visible, 0001h invisible)
  3702. SeeAlso: AX=0022h,AX=0080h
  3703. --------g-E00025-----------------------------
  3704. INT E0 - PCROBOTS v1.41 - "L_ATAN2" - GET ARCTANGENT
  3705.     AX = 0025h
  3706.     BX = Y
  3707.     CX = X
  3708. Return: AX = angle (arctangent of Y/X)
  3709. --------g-E00026-----------------------------
  3710. INT E0 - PCROBOTS v1.41 - "GET_ROBOT_ID" - DETERMINE CURRENT ROBOT'S IDENTIFIER
  3711.     AX = 0026h
  3712. Return: AX = robot ID
  3713. --------g-E00027-----------------------------
  3714. INT E0 - PCROBOTS v1.41 - "REGISTER_IFF" - REGISTER FRIEND/FOE IDENT STRING
  3715.     AX = 0027h
  3716.     BX:CX = ASCIZ IFF string
  3717. Return: nothing
  3718. Note:    the IFF string may only be set once
  3719. SeeAlso: AX=0028h,AX=0029h
  3720. --------g-E00028-----------------------------
  3721. INT E0 - PCROBOTS v1.41 - "CHECK_IFF" - QUERY FRIEND/FOE IDENTIFICATION STRING
  3722.     AX = 0028h
  3723.     BX = robot ID to test
  3724. Return: AX = status
  3725.         0000h IFF strings match
  3726.         0001h IFF strings differ or invalid robot ID
  3727. SeeAlso: AX=0027h
  3728. --------g-E00029-----------------------------
  3729. INT E0 - PCROBOTS v1.41 - "REGISTER_NAME" - SPECIFY ROBOT'S NAME
  3730.     AX = 0029h
  3731.     BX:CX -> ASCIZ name string
  3732. Return: nothing
  3733. Note:    the name may only be set once
  3734. SeeAlso: AX=0027h,AX=002Ah
  3735. --------g-E0002A-----------------------------
  3736. INT E0 - PCROBOTS v1.41 - "FIND_NAME" - SEARCH FOR ROBOT WITH GIVEN NAME
  3737.     AX = 002Ah
  3738.     BX:CX -> ASCIZ name string
  3739.     DX = first ID to check
  3740. Return: AX = robot ID or FFFFh if no robot with specified name
  3741. SeeAlso: AX=0028h,AX=0029h,AX=002Bh
  3742. --------g-E0002B-----------------------------
  3743. INT E0 - PCROBOTS v1.41 - "GET_TEAM_ID" - DETERMINE TEAM MEMBERSHIP OF ROBOT
  3744.     AX = 002Bh
  3745. Return: AX = team ID (0-2) or FFFFh if 'loner'
  3746. SeeAlso: AX=0029h
  3747. --------g-E0002C-----------------------------
  3748. INT E0 - PCROBOTS v1.41 - "GET_ASHELL_STATUS" - FIND OUT WHAT HAPPENED TO SHELL
  3749.     AX = 002Ch
  3750.     BX = shell ID
  3751. Return: AX = status
  3752.         0000h missed completely
  3753.         0001h hit a wall
  3754.         0002h hit a robot within a 50-square radius
  3755.         0003h hit a robot within a 25-square radius
  3756.         0004h hit a robot within a 5-square radius
  3757.         0005h shell not known (too old or not yet fired)
  3758.         0006h shell still in flight
  3759. SeeAlso: AX=0003h
  3760. --------g-E0002D-----------------------------
  3761. INT E0 - PCROBOTS v1.41 - "REGISTER_X" - SELECT AUTOMATIC X POSITION UPDATES
  3762.     AX = 002Dh
  3763.     BX:CX -> X word variable
  3764. Return: AX = status (0001h OK, 0000h problem with address)
  3765. Note:    after this call, PCROBOTS will automatically update the specified
  3766.       word whenever the robot moves
  3767. SeeAlso: AX=002Eh
  3768. --------g-E0002E-----------------------------
  3769. INT E0 - PCROBOTS v1.41 - "REGISTER_Y" - SELECT AUTOMATIC Y POSITION UPDATES
  3770.     AX = 002Eh
  3771.     BX:CX -> Y word variable
  3772. Return: AX = status (0001h OK, 0000h problem with address)
  3773. Note:    after this call, PCROBOTS will automatically update the specified
  3774.       word whenever the robot moves
  3775. SeeAlso: AX=002Dh
  3776. --------g-E00080-----------------------------
  3777. INT E0 - PCROBOTS v1.41 - "CONFIGURE" - CUSTOMIZE ROBOT
  3778.     AX = 0080h
  3779.     BX = basic configuration (see #3279)
  3780.     CX = advanced configuration (see #3280)
  3781. Return: AX = status (0001h OK, 0000h not first call in program)
  3782. Program: PCROBOTS is P.D. Smith's adaptation of Tom Poindexter's CROBOTS, in
  3783.       which specially-written .COM or .EXE programs form robots battling
  3784.       each other in a user-defined arena
  3785. Notes:    a maximum of ten points may be allocated to the robot; if you attempt
  3786.       to allocate more, some items will be given a value of zero.  If this
  3787.       function is not called, each attribute is set to the default value
  3788.       of 2.
  3789.     if the invisibility option is chosen, the robot will start with only
  3790.       900 cannon shells instead of the default 1000
  3791.  
  3792. Bitfields for PCROBOTS basic configuration:
  3793. Bit(s)    Description    (Table 3279)
  3794.  0-3    maximum speed (0-4 = 50,75,100,150,200)
  3795.  4-7    maneuverability (0-4 = 20%,35%,50%,75%,100%)
  3796.  8-11    cannon range (0-4 = 300,500,700,1000,1500)
  3797.  12-15    robot armor (0-4 = 50,75,100,150,200)
  3798.  
  3799. Bitfields for PCROBOTS advanced configuration:
  3800. Bit(s)    Description    (Table 3280)
  3801.  0-2    robot acceleration (0-4 = 5,7,10,15,20)
  3802.  3    capable of invisibility
  3803. --------r-E1---------------------------------
  3804. INT E1 - IBM ROM BASIC - used while in interpreter
  3805. Notes:    called by ROM BASIC
  3806.     BASIC.COM/BASICA.COM do not restore vector on termination
  3807. --------N-E1---------------------------------
  3808. INT E1 - PC Cluster Disk Server Information (NOT A VECTOR!)
  3809. Desc:    points at a data table
  3810. SeeAlso: INT E2
  3811. --------O-E1---------------------------------
  3812. INT E1 - MP/M-86, - ALTERNATE CP/M-86 FUNCTION CALLS
  3813.     CL = function number (see #3268,#3269)
  3814.     DS,DX = parameters
  3815. Return: as appropriate for function
  3816.     CX is often the error code (see #3270)
  3817. Desc:    used by some applications which alter CP/M functions while running a
  3818.       child program, to store the original INT E0 vector before
  3819.       intercepting INT E0
  3820. SeeAlso: INT E0"CP/M"
  3821. ----------E1---------------------------------
  3822. INT E1 - DeskMate (Tandy) - TASK DATA SEGMENTS (NOT A VECTOR!)
  3823. Desc:    used to store data; the    low word of the vector is the data segment for
  3824.       the first task; the high word is the data segment of the second task
  3825.       (DeskMate supports 2-way task switching between small- or
  3826.       medium-model applications)
  3827. Program: DeskMate is a proprietary GUI from Tandy distributed with several
  3828.       models of the Tandy 1000's, 2500's, 3000's, and laptops.  Retail
  3829.       and runtime versions also exist.  Some Tandy's are designed to
  3830.       boot directly into DeskMate.
  3831. SeeAlso: INT E0"DeskMate"
  3832. --------r-E2---------------------------------
  3833. INT E2 - IBM ROM BASIC - used while in interpreter
  3834. Notes:    called by ROM BASIC
  3835.     BASIC.COM/BASICA.COM do not restore vector on termination
  3836. --------N-E2---------------------------------
  3837. INT E2 - PC Cluster Program - RELOCATED INT 1C
  3838. SeeAlso: INT 1C
  3839. --------r-E3---------------------------------
  3840. INT E3 - IBM ROM BASIC - used while in interpreter
  3841. Notes:    called by ROM BASIC
  3842.     BASIC.COM/BASICA.COM do not restore vector on termination
  3843. --------r-E40005-----------------------------
  3844. INT E4 - Logitech Modula v2.0 - MonitorEntry
  3845.     AX = 0005h
  3846.     BX = priority
  3847. Return: nothing
  3848. SeeAlso: AX=0006h
  3849. --------r-E40006-----------------------------
  3850. INT E4 - Logitech Modula v2.0 - MonitorExit
  3851.     AX = 0006h
  3852. Return: nothing
  3853. SeeAlso: AX=0005h
  3854. --------r-E4---------------------------------
  3855. INT E4 - IBM ROM BASIC - used while in interpreter
  3856. Notes:    called by ROM BASIC
  3857.     BASIC.COM/BASICA.COM do not restore vector on termination
  3858. --------r-E5---------------------------------
  3859. INT E5 - IBM ROM BASIC - used while in interpreter
  3860. Notes:    called by ROM BASIC, but pointed at IRET by BASIC.COM/BASICA.COM
  3861.     BASIC.COM/BASICA.COM do not restore vector on termination
  3862. --------r-E6---------------------------------
  3863. INT E6 - IBM ROM BASIC - used while in interpreter
  3864. Notes:    called by ROM BASIC
  3865.     BASIC.COM/BASICA.COM do not restore vector on termination
  3866. --------O-E600-------------------------------
  3867. INT E6 - Linux DOSEMU - INSTALLATION CHECK
  3868.     AH = 00h
  3869. Return: AX = AA55h if installed
  3870.         BH = major version number
  3871.         BL = minor version number
  3872.         CX = patchlevel
  3873. Notes:    check for the BIOS date string "02/25/93" at F000:FFF5 before
  3874.       calling this function.  In addition, the segment address of this
  3875.       vector should be F000h (for existing versions of DOSemu, the
  3876.       vector is F000h:0E60h)
  3877. SeeAlso: AH=FFh
  3878. --------O-E601-------------------------------
  3879. INT E6 - Linux DOSEMU - REGISTER DUMP
  3880.     AH = 01h
  3881. Return: nothing
  3882. SeeAlso: AH=00h
  3883. --------O-E602-------------------------------
  3884. INT E6 - Linux DOSEMU - SET I/O PORT PERMISSIONS
  3885.     AH = 02h
  3886.     BX = base I/O port address
  3887.     CX = number of consecutive I/O ports
  3888.     CF set to allow DOS to use ports
  3889.     CF clear if DOS should not be allowed to use ports
  3890. Return: nothing
  3891. SeeAlso: AH=00h
  3892. --------O-E605-------------------------------
  3893. INT E6 - Linux DOSEMU - STARTUP BANNER
  3894.     AH = 05h
  3895. Return: nothing
  3896. SeeAlso: AH=00h
  3897. --------O-E612-------------------------------
  3898. INT E6 - Linux DOSEMU - SET "HOGTHRESHOLD"
  3899.     AH = 12h
  3900.     BX = new "hogthreshold" (00h-99h)
  3901. Return: nothing
  3902. Desc:    specify how much CPU time DOSEMU may use
  3903. SeeAlso: AH=00h
  3904. --------O-E622-------------------------------
  3905. INT E6 - Linux DOSEMU - GET EMS STATUS
  3906.     AH = 22h
  3907. Return: ???
  3908. SeeAlso: AH=00h
  3909. --------O-E630-------------------------------
  3910. INT E6 - Linux DOSEMU - SET BOOTDISK FLAG
  3911.     AH = 30h
  3912.     BX = new flag state (0 = false, 1 = true)
  3913. Return: nothing
  3914. SeeAlso: AH=00h
  3915. --------O-E650-------------------------------
  3916. INT E6 - Linux DOSEMU - EXECUTE UNIX COMMAND
  3917.     AH = 50h
  3918.     ES:DX -> ASCIZ Unix command
  3919. SeeAlso: AH=00h,AH=51h
  3920. --------O-E651-------------------------------
  3921. INT E6 - Linux DOSEMU - EXECUTE DOS COMMAND FROM UNIX
  3922.     AH = 51h
  3923.     ES:DX -> ASCIZ DOS command
  3924. SeeAlso: AH=00h,AH=50h
  3925. --------O-E680-------------------------------
  3926. INT E6 - Linux DOSEMU - GET CURRENT UNIX DIRECTORY
  3927.     AH = 80h
  3928. Return: ES:DX -> current Unix directory
  3929.     AX = length of current directory name
  3930. SeeAlso: AH=00h,AH=81h
  3931. --------O-E681-------------------------------
  3932. INT E6 - Linux DOSEMU - CHANGE CURRENT UNIX DIRECTORY
  3933.     AH = 81h
  3934.     ES:DX -> ASCIZ directory name
  3935. Return: nothing
  3936. SeeAlso: AH=00h,AH=80h
  3937. --------O-E6FF-------------------------------
  3938. INT E6 - Linux DOSEMU - TERMINATE
  3939.     AH = FFh
  3940. SeeAlso: AH=00h
  3941. --------r-E7---------------------------------
  3942. INT E7 - IBM ROM BASIC - used while in interpreter
  3943. Notes:    called by ROM BASIC
  3944.     BASIC.COM/BASICA.COM do not restore vector on termination
  3945. --------r-E8---------------------------------
  3946. INT E8 - IBM ROM BASIC - used while in interpreter
  3947. Notes:    called by ROM BASIC, but pointed at IRET by BASIC.COM/BASICA.COM
  3948.     BASIC.COM/BASICA.COM do not restore vector on termination
  3949. --------r-E9---------------------------------
  3950. INT E9 - IBM ROM BASIC - used while in interpreter
  3951. Notes:    called by ROM BASIC
  3952.     BASIC.COM/BASICA.COM do not restore vector on termination
  3953. --------r-EA---------------------------------
  3954. INT EA - IBM ROM BASIC - used while in interpreter
  3955. Notes:    called by ROM BASIC
  3956.     BASIC.COM/BASICA.COM do not restore vector on termination
  3957. --------r-EB---------------------------------
  3958. INT EB - IBM ROM BASIC - used while in interpreter
  3959. Notes:    called by ROM BASIC
  3960.     BASIC.COM/BASICA.COM do not restore vector on termination
  3961. --------r-EC---------------------------------
  3962. INT EC - IBM ROM BASIC - used while in interpreter
  3963. Notes:    called by ROM BASIC
  3964.     BASIC.COM/BASICA.COM do not restore vector on termination
  3965. --------N-EC---------------------------------
  3966. INT EC - used by Alloy NTNX
  3967. --------r-EC---------------------------------
  3968. INT EC - Exact - RUNTIME INTERFACE MULTIPLEXOR
  3969.     AX = function number (0000h to 0140h)
  3970.     STACK:    DWORD address to return to
  3971.         any arguments required by function
  3972. Return: STACK:    return address popped, but otherwise unchanged
  3973. Desc:    this is the interface from applications to the runtime system by Exact
  3974.       Automatisering B.V. of the Netherlands.  By using this interrupt,
  3975.       it can provide DLL-style capabilities under MS-DOS.
  3976. Note:    the interrupt handler removes the return address and flags placed on
  3977.       the stack by the INT EC, then jumps to the appropriate function
  3978. --------r-ED---------------------------------
  3979. INT ED - IBM ROM BASIC - used while in interpreter
  3980. Notes:    called by ROM BASIC, but pointed at IRET by BASIC.COM/BASICA.COM
  3981.     BASIC.COM/BASICA.COM do not restore vector on termination
  3982.     INT 80 through INT ED are modified but not restored by Direct Access
  3983.       v4.0, and may be left dangling by other programs written with the
  3984.       same version of compiled BASIC
  3985. SeeAlso: INT EC"BASIC",INT EE"BASIC"
  3986. --------r-EE---------------------------------
  3987. INT EE - IBM ROM BASIC - used while in interpreter
  3988. Notes:    called by ROM BASIC, but pointed at IRET by BASIC.COM/BASICA.COM
  3989.     BASIC.COM/BASICA.COM do not restore vector on termination
  3990. SeeAlso: INT ED"BASIC",INT EE"BASIC"
  3991. --------r-EF---------------------------------
  3992. INT EF - BASIC - ORIGINAL INT 09 VECTOR
  3993. Note:    BASIC.COM/BASICA.COM do not restore vector on termination
  3994. SeeAlso: INT EE"BASIC",INT F0"BASIC"
  3995. --------O-EF----CX0473-----------------------
  3996. INT EF - GEM - INTERFACE
  3997.     CX = 0473h
  3998.     DS:DX -> GEM parameter block
  3999. --------r-F0---------------------------------
  4000. INT F0 - BASICA.COM, GWBASIC, compiled BASIC - ORIGINAL INT 08 VECTOR
  4001. Note:    BASICA.COM does not restore vector on termination
  4002. SeeAlso: INT EF"BASIC"
  4003. --------*-F1---------------------------------
  4004. INT F1 - reserved for user interrupt
  4005. --------s-F1---------------------------------
  4006. INT F1 - SPEECH.COM - CONVERT TEXT STRING TO SPEECH
  4007.     DS:BX -> '$'-terminated text string
  4008. Return: nothing
  4009. Program: SPEECH.COM is a resident text-to-speech converter by Douglas Sisco
  4010. --------s-F1---------------------------------
  4011. INT F1 - Andy C. McGuire SPEECH.COM/SAY.COM
  4012. SeeAlso: INT F2"SPEECH"
  4013. --------U-F1---------------------------------
  4014. INT F1 - AQUEDUCT, PIPELINE - GET DATA AREA ADDRESS
  4015. Return: AX:BX -> data area
  4016. Program: AQUEDUCT and PIPELINE are TSRs by James W. Birdsall to connect COM1
  4017.       and COM2 in software
  4018. Note:    The installation check consists of testing for the following signature
  4019.       immediately preceding the interrupt handler: "JWBtvv" where 't' is
  4020.       either "A" for AQUEDUCT or "P" for PIPELINE and "vv" is a two-digit
  4021.       version number
  4022. Index:    installation check;AQUEDUCT|installation check;PIPELINE
  4023. --------N-F1---------------------------------
  4024. INT F1 - NetWare Remote Boot - INSTALLATION CHECK (NOT A VECTOR!)
  4025. Note:    if this vector contains the value 5774654Eh ("NetW"), the remote boot
  4026.       BIOS extension is active, and access to the floppy disk is redirected
  4027.       to an image file in the server's SYS:LOGIN directory
  4028. SeeAlso: INT F2"NetWare",INT F3"NetWare",INT F4"NetWare"
  4029. --------v-F1---------------------------------
  4030. INT F1 - VIRUS - "Violetta" - ???
  4031. Note:    used but not chained by virus
  4032. SeeAlso: INT E0"VIRUS",INT FF"VIRUS"
  4033. ----------F101-------------------------------
  4034. INT F1 - Common ISDN API (CAPI) v1.1 - "API-REGISTER" - INITIALIZE CAPI
  4035.     AH = 01h
  4036.     ES:BX -> buffer for CAPI's use (refer to note below)
  4037.     CX = minimum number of pending messages
  4038.     DX = maximum simultaneous Level 3 connections
  4039.     SI = maximum concurrent received B3 data blocks
  4040.     DI = maximum B3 data block size
  4041. Return: AX = CAPI-assigned application ID
  4042.         0000h on error
  4043.         BX = error number
  4044.             1001h registration error
  4045. Range:    INT 00 to INT FF, selectable by program parameter
  4046. Notes:    the caller is required to provide at least 512 bytes of stack space
  4047.     the CAPI interrupt handler begins with a header which is nearly
  4048.       identical to the IBM Interrupt Sharing Protocol header
  4049.       (see #1903 at INT 2D"AMIS"), except that the short jump instruction
  4050.       to a hardware reset handler at offset 09h is replaced by the
  4051.       signature bytes "IA"
  4052.     the maximum length of a message is fixed at 180 bytes; the standard
  4053.       document suggests using CX=10, DI=1, SI=7, and DI=130 for
  4054.       applications which use only a single connection and standard
  4055.       protocols
  4056.     the total size of the application-provided buffer must be at least
  4057.       180*CX + DX*SI*DI bytes
  4058. SeeAlso: AH=02h,INT F1/AL=01h
  4059. Index:    installation check;Common ISDN API
  4060. ----------F1--01-----------------------------
  4061. INT F1 - Common ISDN API (CAPI) v2.0 - "CAPI_REGISTER" - INITIALIZE CAPI
  4062.     AL = 01h
  4063.     AH = CAPI version number * 10 (14h for v2.0)
  4064.     ES:BX -> buffer for CAPI's use (refer to note below)
  4065.     CX = number of bytes for message buffer
  4066.     DX = maximum simultaneous logical (Level 3) connections
  4067.     SI = maximum concurrent received B3 data blocks (min. 2)
  4068.     DI = maximum B3 data block size (up to 2048 bytes)
  4069. Return: AX = CAPI-assigned application ID
  4070.         0000h on error
  4071.         BX = error number
  4072.             1001h registration error
  4073. Range:    INT 00 to INT FF, selectable by program parameter
  4074. Notes:    the caller is required to provide at least 512 bytes of stack space
  4075.     the CAPI interrupt handler begins with a header (see #3281) which is
  4076.       nearly identical to the IBM Interrupt Sharing Protocol header
  4077.       (see #1903 at INT 2D"AMIS"), except that the short jump instruction
  4078.       to a hardware reset handler at offset 09h is zeroed out and the
  4079.       entire header is inexplicably shortened by one byte
  4080.     the standard document suggests using 1024 + (1024*DX) bytes for the
  4081.       message buffer for typical applications
  4082.     the total size of the application-provided buffer must be at least
  4083.       CX + DX*SI*DI bytes
  4084. SeeAlso: AH=01h,INT F1/AL=02h
  4085. Index:    installation check;Common ISDN API
  4086.  
  4087. Format of CAPI v2.0 interrupt handler entry point:
  4088. Offset    Size    Description    (Table 3281)
  4089.  00h  2 BYTEs    short jump to actual start of interrupt handler, immediately
  4090.           following this data block (EBh 0Fh)
  4091.  02h    DWORD    address of next handler in chain
  4092.  06h    WORD    signature 424Bh
  4093.  08h    BYTE    EOI flag (80h)
  4094.         80h primary hardware interrupt handler (will issue EOI)
  4095.  09h  2 BYTEs    reserved (0)
  4096.         (is short jump to hardware reset routine in ISP header)
  4097.  0Bh  4 BYTEs    signature "CAPI"
  4098.  0Fh  2 BYTEs    two-digit CAPI version number in ASCII ('20')
  4099. SeeAlso: #1903 at INT 2D
  4100. ----------F102-------------------------------
  4101. INT F1 - Common ISDN API (CAPI) v1.1 - "API-RELEASE" - UNREGISTER FROM CAPI
  4102.     AH = 02h
  4103.     DX = application ID (see AH=01h)
  4104. Return: AX = status (0000h,1002h) (see #3282)
  4105. Notes:    the caller is required to provide at least 512 bytes of stack space
  4106. SeeAlso: AH=01h,INT F1/AL=02h
  4107.  
  4108. (Table 3282)
  4109. Values for CAPI v1.1 error code:
  4110.  0000h    successful
  4111.  1001h    registration error
  4112.  1002h    invalid application ID
  4113.  1003h    message too small or incorrectly coded message number
  4114.  1004h    invalid command or subcommand
  4115.  1005h    message queue full
  4116.  1006h    message queue empty
  4117.  1007h    message(s) lost due to queue overflow
  4118.  1008h    error uninstalling
  4119. SeeAlso: #3283
  4120. ----------F1--02-----------------------------
  4121. INT F1 - Common ISDN API (CAPI) v2.0 - "CAPI_RELEASE" - UNREGISTER FROM CAPI
  4122.     AL = 02h
  4123.     AH = CAPI version number * 10 (14h for v2.0)
  4124.     DX = application ID (see INT F1/AL=01h)
  4125. Return: AX = status (0000h,11xxh) (see #3283)
  4126. Notes:    the caller is required to provide at least 512 bytes of stack space
  4127. SeeAlso: AH=02h,INT F1/AL=01h,INT F1/AL=03h
  4128.  
  4129. (Table 3283)
  4130. Values for CAPI v2.0 error code:
  4131.  0000h    successful
  4132.  1001h    too many applications
  4133.  1002h    logical block size too small (must be at least 128 bytes)
  4134.  1003h    buffer > 64K
  4135.  1004h    message buffer too small (minimum 1024 bytes)
  4136.  1005h    too many logical connections requested
  4137.  1006h    reserved
  4138.  1007h    could not register because CAPI busy, try again
  4139.  1008h    OS resource unavailable (out of memory, etc.)
  4140.  1009h    COMMON-ISDN-API not installed
  4141.  100Ah    controller does not support external equipment
  4142.  100Bh    controller supports only external equipment
  4143.  1101h    invalid application ID
  4144.  1102h    illegal comand or subcommand, or message too short
  4145.  1103h    message queue full
  4146.  1104h    queue empty
  4147.  1105h    queue overflowed (message lost)
  4148.  1106h    unknown notification parameter
  4149.  1107h    could not accept message because CAPI busy, try again
  4150.  1108h    OS resource unavailable (out of memory, etc.)
  4151.  1109h    COMMON-ISDN-API not installed
  4152.  110Ah    controller does not support external equipment
  4153.  110Bh    controller supports only external equipment
  4154.  2001h    message not supported in current state
  4155.  2002h    illegal controller/PLCI/NCCI
  4156.  2003h    out of PLCI
  4157.  2004h    out of NCCI
  4158.  2005h    out of LISTEN
  4159.  2006h    out of FAX resources (T.30 protocol)
  4160.  2007h    illegal message parameter coding
  4161.  3001h    unsupported B1 protocol
  4162.  3002h    unsupported B2 protocol
  4163.  3003h    unsupported B3 protocol
  4164.  3004h    unsupported B1 protocol parameter
  4165.  3005h    unsupported B2 protocol parameter
  4166.  3006h    unsupported B3 protocol parameter
  4167.  3007h    unsupported B protocol combination
  4168.  3008h    NCPI not supported
  4169.  3009h    unknown CIP value
  4170.  300Ah    unsupported flags (reserved bits set)
  4171.  300Bh    unsupported facility
  4172.  300Ch    data length not supported by current protocol
  4173.  300Dh    reset procedure not supported by current protocol
  4174. SeeAlso: #3282
  4175. ----------F103-------------------------------
  4176. INT F1 - Common ISDN API (CAPI) v1.1 - "API-PUT-MESSAGE"
  4177.     AH = 03h
  4178.     DX = application ID (see AH=01h)
  4179.     ES:BX -> message to be sent (see #3284)
  4180. Return: AX = status (0000h,1002h,1003h,1004h,1005h) (see #3282)
  4181. Notes:    the caller is required to provide at least 512 bytes of stack space
  4182.     the message buffer may be reused as soon as this call returns
  4183. SeeAlso: AH=01h,AH=04h,INT F1/AL=03h
  4184.  
  4185. Format of CAPI message:
  4186. Offset    Size    Description    (Table 3284)
  4187.  00h    WORD    total message length, including header
  4188.  02h    WORD    application ID (see AH=01h)
  4189.  04h    BYTE    command (see #3285,#3286)
  4190.  05h    BYTE    subcommand (see #3285,#3286)
  4191.  06h    WORD    message sequence number
  4192.         0000h-7FFFh messages from application to CAPI (and replies)
  4193.         8000h-FFFFh messages from CAPI to application (and replies)
  4194.  08h    var    message data (max 172 bytes for v1.1 only)
  4195.  
  4196. (Table 3285)
  4197. Values for CAPI v1.1 message command/subcommand:
  4198. Cmd/SubCmd    Name            Description
  4199.  01h/00h    RESET-B3-REQ    request resetting of a Level 3 connection
  4200.  01h/01h    RESET-B3-CONF    confirm Level 3 connection reset
  4201.  01h/02h    RESET-B3-IND    indication from CAPI that Level 3 conn. reset
  4202.  01h/03h    RESET-B3-RESP    confirm receipt of RESET-B3-IND
  4203.  02h/00h    CONNECT-REQ        establish B-channel connection
  4204.  02h/01h    CONNECT-CONF    confirm start of connection establishment
  4205.  02h/02h    CONNECT-IND        indication from CAPI of incoming connection
  4206.  02h/03h    CONNECT-RESP    accept incoming connection
  4207.  03h/02h    CONNECT-ACTIVE-IND    indication that B-channel connection complete
  4208.  03h/03h    CONNECT-ACTIVE-RESP    confirm connection-complete indication
  4209.  04h/00h    DISCONNECT-REQ    request shutdown of B-channel connection
  4210.  04h/01h    DISCONNECT-CONF    confirm shutdown of B-channel connection
  4211.  04h/02h    DISCONNECT-IND    indication that B-channel is shutting down
  4212.  04h/03h    DISCONNECT-RESP    confirm that application knows of shutdown
  4213.  05h/00h    LISTEN-REQ        enable indication of incoming connections
  4214.  05h/01h    LISTEN-CONF        confirm enabling of incoming conn. indication
  4215.  06h/00h    GET-PARAMS-REQ    request B-channel parameters
  4216.  06h/01h    GET-PARAMS-CONF    return B-channel parameters
  4217.  07h/00h    INFO-REQ        set B-channel info to be signalled to app
  4218.  07h/01h    INFO-CONF        confirm B-channel info signalling
  4219.  07h/02h    INFO-IND        signal B-channel events to application
  4220.  07h/03h    INFO-CONF        confirm receipt of INFO-IND
  4221.  08h/00h    DATA-REQ        send D-channel data
  4222.  08h/01h    DATA-CONF        confirm receipt of DATA-REQ
  4223.  08h/02h    DATA-IND        receive D-channel data
  4224.  08h/03h    DATA-RESP        confirm receipt fo DATA-IND
  4225.  09h/00h    CONNECT-INFO-REQ    request connection information
  4226.  09h/01h    CONNECT-INFO-CONF    return connection information
  4227.  40h/00h    SELECT-B2-PROTOCOL-REQ  select Level 2 protocol
  4228.  40h/01h    SELECT-B2-PROTOCOL-CONF confirm receipt of SELECT-B2-PROTOCOL-REQ
  4229.  80h/00h    SELECT-B3-PROTOCOL-REQ  select Level 3 protocol
  4230.  80h/01h    SELECT-B3-PROTOCOL-CONF confirm receipt of SELECT-B3-PROTOCOL-REQ
  4231.  81h/00h    LISTEN-B3-REQ    enable notification of incoming Level 3 calls
  4232.  81h/01h    LISTEN-B3-CONF    confirm receipt of LISTEN-B3-REQ
  4233.  82h/00h    CONNECT-B3-REQ    establish Level 3 connection
  4234.  82h/01h    CONNECT-B3-CONF    confirm start of connection establishment
  4235.  82h/02h    CONNECT-B3-IND    indication of incoming Level 3 connection
  4236.  82h/03h    CONNECT-B3-RESP    accept incoming connection
  4237.  83h/02h    CONNECT-B3-ACTIVE-IND  indication that Level 3 connection complete
  4238.  83h/03h    CONNECT-B3-ACTIVE-RESP confirm connection-complete indication
  4239.  84h/00h    DISCONNECT-B3-REQ    request shutdown of Level 3 connection
  4240.  84h/01h    DISCONNECT-B3-CONF    confirm shutdown of Level 3 connection
  4241.  84h/02h    DISCONNECT-B3-IND    indication that Level 3 is shutting down
  4242.  84h/03h    DISCONNECT-B3-RESP    confirm that application knows of shutdown
  4243.  85h/00h    GET-B3-PARAMS-REQ    request Level 3 parameters
  4244.  85h/01h    GET-B3-PARAMS-CONF    return Level 3 parameters
  4245.  86h/00h    DATA-B3-REQ        send data on Level 3
  4246.  86h/01h    DATA-B3-CONF    confirm sending of Level 3 data
  4247.  86h/02h    DATA-B3-IND        indication of incoming Level 3 data
  4248.  86h/03h    DATA-B3-RESP    confirm receipt of Level 3 data
  4249.  87h/02h    HANDSET-IND        indication of Handset events
  4250.  87h/03h    HANDSET-RESP    confirm receipt of Handset event
  4251.  FFh/00h    MANUFACTURER-REQ    vendor-specific request
  4252.  FFh/01h    MANUFACTURER-CONF    vendor-specific request confirmation
  4253.  FFh/02h    MANUFACTURER-IND    vendor-specific notification
  4254.  FFh/03h    MANUFACTURER-RESP    vendor-specific notification confirmation
  4255. SeeAlso: #3284,#3286
  4256. ----------F1--03-----------------------------
  4257. INT F1 - Common ISDN API (CAPI) v2.0 - "CAPI_PUT_MESSAGE"
  4258.     AL = 03h
  4259.     AH = CAPI version number * 10 (14h for v2.0)
  4260.     DX = application ID (see INT F1/AL=01h)
  4261.     ES:BX -> message to be sent (see #3284)
  4262. Return: AX = status (0000h,11xxh) (see #3283)
  4263. Notes:    the caller is required to provide at least 512 bytes of stack space
  4264.     the message buffer may be reused as soon as this call returns
  4265. SeeAlso: AH=03h,INT F1/AL=01h,INT F1/AL=04h
  4266.  
  4267. (Table 3286)
  4268. Values for CAPI v2.0 message command/subcommand:
  4269. Cmd/SubCmd    Name            Description
  4270.  01h/80h    ALERT_REQ        indicate compatibility with incoming calls
  4271.  01h/81h    ALERT_CONF        confirm receipt of ALERT_REQ
  4272.  02h/80h    CONNECT_REQ        establish B-channel connection
  4273.  02h/81h    CONNECT_CONF    confirm start of connection establishment
  4274.  02h/82h    CONNECT_IND        indication from CAPI of incoming connection
  4275.  02h/83h    CONNECT_RESP    accept incoming connection
  4276.  03h/82h    CONNECT_ACTIVE_IND    indication that B-channel connection complete
  4277.  03h/83h    CONNECT_ACTIVE_RESP    confirm connection-complete indication
  4278.  04h/80h    DISCONNECT_REQ    request shutdown of B-channel connection
  4279.  04h/81h    DISCONNECT_CONF    confirm shutdown of B-channel connection
  4280.  04h/82h    DISCONNECT_IND    indication that B-channel is shutting down
  4281.  04h/83h    DISCONNECT_RESP    confirm that application knows of shutdown
  4282.  05h/80h    LISTEN_REQ        enable signalling on incoming events
  4283.  05h/81h    LISTEN_CONF        confirm enabling of incoming event signalling
  4284.  08h/80h    INFO_REQ        send protocol information for physical connect
  4285.  08h/81h    INFO_CONF        confirm INFO_REQ
  4286.  08h/82h    INFO_IND        indicate event for physical connection
  4287.  08h/83h    INFO_CONF        confirm receipt of INFO_IND
  4288.  41h/80h    SELECT_B_PROTOCOL_REQ   change protocol on already-active connect
  4289.  41h/81h    SELECT_B_PROTOCOL_CONF  confirm receipt of SELECT_B_PROTOCOL_REQ
  4290.  80h/80h    FACILITY_REQ    control optional facilities
  4291.  80h/81h    FACILITY_CONF    confirm acceptance of FACILITY_REQ
  4292.  80h/82h    FACILITY_IND    indicate facility-dependent event
  4293.  80h/83h    FACILITY_RESP    confirm receipt of FACILITY_IND
  4294.  82h/80h    CONNECT_B3_REQ    establish Level 3 connection
  4295.  82h/81h    CONNECT_B3_CONF    confirm start of connection establishment
  4296.  82h/82h    CONNECT_B3_IND    indication of incoming Level 3 connection
  4297.  82h/83h    CONNECT_B3_RESP    accept incoming connection
  4298.  83h/82h    CONNECT_B3_ACTIVE_IND  indication that Level 3 connection complete
  4299.  83h/83h    CONNECT_B3_ACTIVE_RESP confirm connection-complete indication
  4300.  84h/80h    DISCONNECT_B3_REQ    request shutdown of Level 3 connection
  4301.  84h/81h    DISCONNECT_B3_CONF    confirm shutdown of Level 3 connection
  4302.  84h/82h    DISCONNECT_B3_IND    indication that Level 3 is shutting down
  4303.  84h/83h    DISCONNECT_B3_RESP    confirm that application knows of shutdown
  4304.  85h/80h    GET_B3_PARAMS_REQ    request Level 3 parameters
  4305.  85h/81h    GET_B3_PARAMS_CONF    return Level 3 parameters
  4306.  86h/80h    DATA_B3_REQ        send data on Level 3
  4307.  86h/81h    DATA_B3_CONF    confirm sending of Level 3 data
  4308.  86h/82h    DATA_B3_IND        indication of incoming Level 3 data
  4309.  86h/83h    DATA_B3_RESP    confirm receipt of Level 3 data
  4310.  87h/80h    RESET_B3_REQ    request resetting of a logical connection
  4311.  87h/81h    RESET_B3_CONF    confirm logical connection reset
  4312.  87h/82h    RESET_B3_IND    indication from CAPI that logical conn. reset
  4313.  87h/83h    RESET_B3_RESP    confirm receipt of RESET_B3_IND
  4314.  88h/82h    CONNECT_B3_T90_ACTIVE_IND  indicate switch from T.70 to T.90
  4315.  88h/83h    CONNECT_B3_T90_ACTIVE_RESP confirm receipt of T90_ACTIVE_IND
  4316.  FFh/80h    MANUFACTURER_REQ    vendor-specific request
  4317.  FFh/81h    MANUFACTURER_CONF    vendor-specific request confirmation
  4318.  FFh/82h    MANUFACTURER_IND    vendor-specific notification
  4319.  FFh/83h    MANUFACTURER_RESP    vendor-specific notification confirmation
  4320. SeeAlso: #3284,#3285
  4321. ----------F104-------------------------------
  4322. INT F1 - Common ISDN API (CAPI) v1.1 - "API-GET-MESSAGE"
  4323.     AH = 04h
  4324.     DX = application ID (see AH=01h)
  4325. Return: AX = status (0000h,1002h,1006h,1007h) (see #3282)
  4326.     ES:BX -> message if successful (see #3284)
  4327. Range:    INT 00 to INT FF, selectable by program parameter
  4328. Notes:    the caller is required to provide at least 512 bytes of stack space
  4329.     the returned message may be overwritten by the next call to this
  4330.       function
  4331. SeeAlso: AH=03h
  4332. ----------F1--04-----------------------------
  4333. INT F1 - Common ISDN API (CAPI) v2.0 - "CAPI_GET_MESSAGE"
  4334.     AL = 04h
  4335.     AH = CAPI version number * 10 (14h for v2.0)
  4336.     DX = application ID (see AH=01h)
  4337. Return: AX = status (0000h,11xxh) (see #3283)
  4338.     ES:BX -> message if successful (see #3284)
  4339. Range:    INT 00 to INT FF, selectable by program parameter
  4340. Notes:    the caller is required to provide at least 512 bytes of stack space
  4341.     the returned message may be overwritten by the next call to this
  4342.       function
  4343. SeeAlso: AH=04h,INT F1/AL=03h
  4344. ----------F105-------------------------------
  4345. INT F1 - Common ISDN API (CAPI) v1.1 - "API-SET-SIGNAL" - SIGNAL HANDLING
  4346.     AH = 05h
  4347.     DX = application ID (see AH=01h)
  4348.     ES:BX -> signal handler or 0000h:0000h to disable
  4349. Return: AX = status (0000h,1002h) (see #3282)
  4350. Notes:    the caller is required to provide at least 512 bytes of stack space
  4351.     the signal handler is called as though it were an interrupt, with
  4352.       interrupts disabled; the handler must preserve all registers and
  4353.       return with an IRET
  4354. SeeAlso: AH=01h
  4355. ----------F1--05-----------------------------
  4356. INT F1 - Common ISDN API (CAPI) v2.0 - "CAPI_SET_SIGNAL" - SIGNAL HANDLING
  4357.     AL = 05h
  4358.     AH = CAPI version number * 10 (14h for v2.0)
  4359.     DX = application ID (see AH=01h)
  4360.     ES:BX -> signal handler or 0000h:0000h to disable
  4361.     SI:DI = parameter to pass to signal handler
  4362. Return: AX = status (0000h,11xxh) (see #3283)
  4363. Notes:    the caller is required to provide at least 512 bytes of stack space
  4364.     the signal handler is called as though it were an interrupt, with
  4365.       interrupts disabled and DX,SI,DI set as they were when this function
  4366.       was called; the handler must preserve all registers and return with
  4367.       an IRET
  4368.     the signal handler may call CAPI_PUT_MESSAGE, CAPI_GET_MESSAGE, and
  4369.       CAPI_SET_SIGNAL
  4370. SeeAlso: INT F1/AL=01h
  4371. ----------F106-------------------------------
  4372. INT F1 - Common ISDN API (CAPI) v1.1 - "API-DEINSTALL" - UNINSTALL
  4373.     AH = 06h
  4374.     BX = force flag
  4375.         0000h normal uninstall
  4376.         0001h forced uninstall
  4377. Return: AX = status (0000h,1008h) (see #3282)
  4378. Desc:    reset ISDN controller, close all ISDN Level 1 connections except for
  4379.       telephone connections
  4380. Notes:    the caller is required to provide at least 512 bytes of stack space
  4381. SeeAlso: INT F1/AL=01h,INT F1/AH=01h
  4382. ----------F1F0-------------------------------
  4383. INT F1 - Common ISDN API (CAPI) v1.1 - "API-GET-MANUFACTURER"
  4384.     AH = F0h
  4385.     ES:BX -> 64-byte buffer for manufacturer identification information
  4386. Return: ES:BX buffer filled with ASCIZ idnetification string
  4387. Range:    INT 00 to INT FF, selectable by program parameter
  4388. Notes:    the caller is required to provide at least 512 bytes of stack space
  4389. SeeAlso: AH=01h,AH=F1h,AH=F2h,AH=FFh,INT F1/AL=F0h
  4390. ----------F1--F0-----------------------------
  4391. INT F1 - Common ISDN API (CAPI) v2.0 - "CAPI_GET_MANUFACTURER"
  4392.     AL = F0h
  4393.     AH = CAPI version number * 10 (14h for v2.0)
  4394.     ES:BX -> 64-byte buffer for manufacturer identification information
  4395. Return: ES:BX buffer filled with ASCIZ idnetification string
  4396. Range:    INT 00 to INT FF, selectable by program parameter
  4397. Notes:    the caller is required to provide at least 512 bytes of stack space
  4398. SeeAlso: AH=F0h,INT F1/AL=01h,INT F1/AL=F1h,INT F1/AL=F2h,INT F1/AL=FFh
  4399. ----------F1F1-------------------------------
  4400. INT F1 - Common ISDN API (CAPI) v1.1 - "API-GET-VERSION"
  4401.     AH = F1h
  4402.     ES:BX -> 64-byte buffer for CAPI version number
  4403. Return: ES:BX buffer filled with ASCIZ version string
  4404. Notes:    the caller is required to provide at least 512 bytes of stack space
  4405. SeeAlso: AH=01h,AH=F0h,AH=F2h,AH=FFh
  4406. ----------F1--F1-----------------------------
  4407. INT F1 - Common ISDN API (CAPI) v2.0 - "CAPI_GET_VERSION"
  4408.     AL = F1h
  4409.     AH = CAPI version number * 10 (14h for v2.0)
  4410. Return: AH = CAPI major version number
  4411.     AL = CAPI minor version number
  4412.     DH = vendor-specific major version
  4413.     DL = vendor-specific minor version
  4414. Notes:    the caller is required to provide at least 512 bytes of stack space
  4415. SeeAlso: AH=F1h,INT F1/AL=01h,INT F1/AL=F0h,INT F1/AL=F2h,INT F1/AL=FFh
  4416. ----------F1F2-------------------------------
  4417. INT F1 - Common ISDN API (CAPI) v1.1 - "API-GET-SERIAL-NUMBER"
  4418.     AH = F2h
  4419.     ES:BX -> 64-byte buffer for CAPI serial number
  4420. Return: ES:BX buffer filled with ASCIZ serial number (seven digits), empty
  4421.           string if no serial number
  4422. Notes:    the caller is required to provide at least 512 bytes of stack space
  4423. SeeAlso: AH=01h,AH=F0h,AH=F1h,AH=FFh
  4424. ----------F1--F2-----------------------------
  4425. INT F1 - Common ISDN API (CAPI) v2.0 - "CAPI_GET_SERIAL_NUMBER"
  4426.     AL = F2h
  4427.     AH = CAPI version number * 10 (14h for v2.0)
  4428.     ES:BX -> 64-byte buffer for CAPI serial number
  4429. Return: ES:BX buffer filled with ASCIZ serial number (seven digits), empty
  4430.           string if no serial number
  4431. Notes:    the caller is required to provide at least 512 bytes of stack space
  4432. SeeAlso: AH=F2h,INT F1/AL=01h,INT F1/AL=F0h,INT F1/AL=F1h,INT F1/AH=F3h
  4433. ----------F1--F3-----------------------------
  4434. INT F1 - Common ISDN API (CAPI) v2.0 - "CAPI_GET_PROFILE" - GET CAPABILITIES
  4435.     AL = F3h
  4436.     AH = CAPI version number * 10 (14h for v2.0)
  4437.     ES:BX -> 64-byte buffer for CAPI capabilities (see #3287)
  4438.     CX = controller number (01h-06h) or 0000h to get number of controllers
  4439. Return: AX = status (0000h,11xxh) (see #3283)
  4440.     ES:BX buffer filled if successful
  4441. Notes:    the caller is required to provide at least 512 bytes of stack space
  4442. SeeAlso: INT F1/AL=01h,INT F1/AL=F0h,INT F1/AL=F2h,INT F1/AH=FFh
  4443.  
  4444. Format of CAPI v2.0 capabilities:
  4445. Offset    Size    Description    (Table 3287)
  4446.  00h    WORD    number of installed controllers
  4447.  02h    WORD    number of supported B channels
  4448.  04h    DWORD    global options (see #3288)
  4449.  08h    DWORD    B1 protocol support flags (see #3289)
  4450.  0Ch    DWORD    B2 protocol support flags (see #3290)
  4451.  10h    DWORD    B3 protocol support flags (see #3291)
  4452.  14h 24 BYTEs    reserved for CAPI use
  4453.  2Ch 20 BYTEs    vendor-specific information
  4454.  
  4455. Bitfields for CAPI v2.0 global options:
  4456. Bit(s)    Description    (Table 3288)
  4457.  0    internal controller supported
  4458.  1    external controller supported
  4459.  2    handset supported (only if bit 1 also set)
  4460.  3    DTMF supported
  4461.  4-31    reserved (0)
  4462. SeeAlso: #3287
  4463.  
  4464. Bitfields for CAPI v2.0 B1 protocol support:
  4465. Bit(s)    Description    (Table 3289)
  4466.  0    64k bps with HDLC framing (required, always set)
  4467.  1    64k bps bit-transparent operation with network byte framing
  4468.  2    V.110 asynchronous with start/stop byte framing
  4469.  3    V.110 synchronous with HDLC framing
  4470.  4    T.30 modem for group 3 FAX
  4471.  5    64k bps inverted with HDLC framing
  4472.  6    56k bps bit-transparent operation with network byte framing
  4473.  7-31    reserved (0)
  4474. SeeAlso: #3287
  4475.  
  4476. Bitfields for CAPI v2.0 B2 protocol support:
  4477. Bit(s)    Description    (Table 3290)
  4478.  0    ISO 7776 (X.75 SLP) (required, always set)
  4479.  1    transparent
  4480.  2    SDLC
  4481.  3    Q.921 LAPD (D-channel X.25)
  4482.  4    T.30 for group 3 FAX
  4483.  5    point-to-point protocol (PPP)
  4484.  6    transparent (ignoring B1 framing errors)
  4485.  7-31    reserved (0)
  4486. SeeAlso: #3287
  4487.  
  4488. Bitfields for CAPI v2.0 B3 protocol support:
  4489. Bit(s)    Description    (Table 3291)
  4490.  0    transparent (required, always set)
  4491.  1    T.90NL with T.70NL compatibility
  4492.  2    ISO 8208 (X.25 DTE-DTE)
  4493.  3    X.25 DCE
  4494.  4    T.30 for group 3 FAX
  4495.  5-31    reserved (0)
  4496. SeeAlso: #3287
  4497. ----------F1FF-------------------------------
  4498. INT F1 - Common ISDN API (CAPI) v1.1 - "API-MANUFACTURER" - VENDOR-SPECIFIC
  4499.     AH = FFh
  4500.     other registers vendor-specific
  4501. Return: registers vendor-specific
  4502. Range:    INT 00 to INT FF, selectable by program parameter
  4503. Notes:    the caller is required to provide at least 512 bytes of stack space
  4504. SeeAlso: AH=01h,AH=F0h,AH=F1h,AH=F2h,INT F1/AH=FFh
  4505. ----------F1--FF-----------------------------
  4506. INT F1 - Common ISDN API (CAPI) v2.0 - "CAPI_MANUFACTURER" - VENDOR-SPECIFIC
  4507.     AL = FFh
  4508.     AH = CAPI version number * 10 (14h for v2.0)
  4509.     other registers vendor-specific
  4510. Return: registers vendor-specific
  4511. Range:    INT 00 to INT FF, selectable by program parameter
  4512. Notes:    the caller is required to provide at least 512 bytes of stack space
  4513. SeeAlso: AH=FFh,INT F1/AL=01h,INT F1/AL=F0h,INT F1/AL=F1h,INT F1/AL=F2h
  4514. --------*-F2---------------------------------
  4515. INT F2 - reserved for user interrupt
  4516. --------s-F2---------------------------------
  4517. INT F2 - Andy C. McGuire SPEECH.COM/SAY.COM
  4518. SeeAlso: INT F1"SPEECH"
  4519. --------N-F2---------------------------------
  4520. INT F2 - NetWare Remote Boot - ORIGINAL INT 13
  4521. SeeAlso: INT F1"NetWare",INT F3"NetWare",INT F4"NetWare"
  4522. ----------F2---------------------------------
  4523. INT F2 - ICCTSR 1.0 - ImageCapture COLOR Developer's Kit - API
  4524.     AH = function number (see #3292)
  4525.     ???
  4526. Return: ???
  4527. Program: ImageCapture is a product of International Computers
  4528. SeeAlso: INT F3"ICCTSR"
  4529.  
  4530. (Table 3292)
  4531. Values for ImageCapture function:
  4532.  01h    power up
  4533.  02h    power down
  4534.  03h    set controls
  4535.  04h    capture image
  4536.  05h    display image
  4537.  06h    read file
  4538.  07h    write file
  4539.  08h    write array
  4540.  09h    read pixel
  4541.  0Ah    write pixel
  4542.  0Bh    check if VGA present
  4543.  0Ch    set video mode
  4544.  0Dh    check for keystroke
  4545.  0Eh    delay
  4546. --------*-F3---------------------------------
  4547. INT F3 - reserved for user interrupt
  4548. SeeAlso: INT F2"user",INT F4"user"
  4549. --------s-F3---------------------------------
  4550. INT F3 - SoundBlaster - POINTER TO ECHO VALUE
  4551. Note:    this is not a vector, but a pointer to a DWORD containing the echo
  4552.       value selected with SET-ECHO.EXE
  4553. SeeAlso: INT 2F/AX=FBFBh/ES=0000h
  4554. ----------F3---------------------------------
  4555. INT F3 - ICCTSR 1.0 - HANDSHAKE ID VECTOR
  4556. Program: ImageCapture is a product of International Computers
  4557. SeeAlso: INT F2"ICCTSR"
  4558. --------N-F3---------------------------------
  4559. INT F3 - NetWare Remote Boot - BOOT ROM'S INT 13 HANDLER
  4560. SeeAlso: INT F1"NetWare",INT F2"NetWare",INT F4"NetWare"
  4561. --------*-F4---------------------------------
  4562. INT F4 - reserved for user interrupt
  4563. SeeAlso: INT F3"user",INT F5"user"
  4564. --------T-F4---------------------------------
  4565. INT F4 - DoubleDOS - GIVE UP REST OF CURRENT CLOCK TICK AND ALL OF NEXT TICK
  4566. SeeAlso: INT 21/AH=EEh"DoubleDOS",INT F5"DoubleDOS",INT FE"DoubleDOS"
  4567. --------N-F4---------------------------------
  4568. INT F4 - NetWare Remote Boot - ???
  4569. SeeAlso: INT F1"NetWare",INT F2"NetWare",INT F3"NetWare"
  4570. --------*-F5---------------------------------
  4571. INT F5 - reserved for user interrupt
  4572. SeeAlso: INT F4"user",INT F6"user"
  4573. --------T-F5---------------------------------
  4574. INT F5 - DoubleDOS - ???
  4575. SeeAlso: INT F4"DoubleDOS",INT F6"DoubleDOS"
  4576. --------*-F6---------------------------------
  4577. INT F6 - reserved for user interrupt
  4578. SeeAlso: INT F5"user",INT F7"user"
  4579. --------T-F6---------------------------------
  4580. INT F6 - DoubleDOS - ???
  4581. SeeAlso: INT F5"DoubleDOS",INT F7"DoubleDOS"
  4582. --------*-F7---------------------------------
  4583. INT F7 - reserved for user interrupt
  4584. SeeAlso: INT F6"user"
  4585. --------T-F7---------------------------------
  4586. INT F7 - DoubleDOS - ???
  4587. SeeAlso: INT F6"DoubleDOS"
  4588. ----------F700-------------------------------
  4589. INT F7 - FSBBS 2.0 - CONFIGURATION RECORD
  4590.     AH = 00h
  4591.     AL = function
  4592.         00h get configuration record
  4593.         Return: DS:DX -> configuration record
  4594.         01h set configuration record
  4595.         Return: nothing
  4596.         02h get path for option
  4597.         DS:DX -> option name
  4598.         Return: DS:DX -> path
  4599.         03h determine whether configuration record set
  4600.         Return: AX = status
  4601.                 0000h set
  4602.                 0001h not yet set
  4603.         04h get link state
  4604.         Return: AX = state
  4605.                 0000h unlinked
  4606.                 0001h linked
  4607. Notes:    this information is preliminary and still subject to change
  4608.     all of the INT F7 calls for FSBBS are used for interprogram
  4609.       communication between the BBS kernel and the programs it spawns
  4610. SeeAlso: AH=01h
  4611. ----------F701-------------------------------
  4612. INT F7 - FSBBS 2.0 - USER RECORD
  4613.     AH = 01h
  4614.     AL = function
  4615.         00h get user record for user currently online
  4616.         Return: DS:DX -> user record
  4617.         01h set user record
  4618.         DS:DX -> user record
  4619.         Return: nothing
  4620. SeeAlso: AH=00h,AH=02h
  4621. ----------F702-------------------------------
  4622. INT F7 - FSBBS 2.0 - GET ACCOUNT NAME
  4623.     AH = 02h
  4624. Return: DS:DX -> 8-character blank-padded account name
  4625. SeeAlso: AH=01h
  4626. ----------F703-------------------------------
  4627. INT F7 - FSBBS 2.0 - TERMINAL NUMBER
  4628.     AH = 03h
  4629.     AL = function
  4630.         00h get terminal index number
  4631.         Return: DX = index number
  4632.         01h set terminal index number
  4633.         DX = terminal index
  4634.         Return: nothing
  4635. ----------F704-------------------------------
  4636. INT F7 - FSBBS 2.0 - PASSDATA BUFFER
  4637.     AH = 04h
  4638.     AL = function
  4639.         00h get PassData buffer contents
  4640.         DS:DX -> buffer for PassData contents
  4641.         Return: DS:DX buffer filled
  4642.         01h set PassData contents
  4643.         DS:DX -> buffer containing new PassData
  4644.         CH = length of data in buffer
  4645.         Return: nothing
  4646. ----------F705-------------------------------
  4647. INT F7 - FSBBS 2.0 - TIMER FUNCTIONS
  4648.     AH = 05h
  4649.     AL = function
  4650.         00h get time remaining
  4651.         Return: DX = number of minutes remaining
  4652.         01h get current time
  4653.         Return: DS:DX -> 8-character time string
  4654.         02h increment time
  4655.         DX = number of additional minutes
  4656.         03h decrement time
  4657.         DX = number of minutes
  4658. SeeAlso: AH=06h
  4659. ----------F706-------------------------------
  4660. INT F7 - FSBBS 2.0 - FUNCTION AVAILABILITY
  4661.     AH = 06h
  4662.     AL = function
  4663.         00h determine whether function is available
  4664.         DX = index of function
  4665.         01h set function availability
  4666.         DX = index of function
  4667.         ???
  4668. Return: nothing
  4669. SeeAlso: AH=05h,AH=07h
  4670. ----------F707-------------------------------
  4671. INT F7 - FSBBS 2.0 - DUMP FUNCTIONS
  4672.     AH = 07h
  4673.     AL = function
  4674.         00h get current dump mode
  4675.         Return: DL = mode
  4676.         01h set dump mode
  4677.         DL = mode
  4678. SeeAlso: AH=06h
  4679. --------*-F8---------------------------------
  4680. INT F8 - reserved for user interrupt
  4681. --------h-F8---------------------------------
  4682. INT F8 - Sanyo MBC-550 - IRQ0 - 100 HZ INTERRUPT
  4683. Note:    normally masked off at 8259 interrupt controller
  4684. SeeAlso: INT 08"IRQ0",INT F9"Sanyo",INT FA"Sanyo"
  4685. --------T-F8---------------------------------
  4686. INT F8 - DoubleDOS - ???
  4687. --------*-F9---------------------------------
  4688. INT F9 - reserved for user interrupt
  4689. --------T-F9---------------------------------
  4690. INT F9 - DoubleDOS - ???
  4691. --------h-F9---------------------------------
  4692. INT F9 - Sanyo MBC-550 - IRQ1 - ???
  4693. Note:    documented as "for system use only"; normally enabled at the 8259
  4694. SeeAlso: INT 09"IRQ1",INT F8"Sanyo",INT FA"Sanyo"
  4695. --------*-FA---------------------------------
  4696. INT FA - reserved for user interrupt
  4697. --------h-FA---------------------------------
  4698. INT FA - Sanyo MBC-550 - IRQ2 - SERIAL PORT USART INTERRUPT
  4699. Note:    this vector is not used on the Tandy 1000TL
  4700. SeeAlso: INT 0A"IRQ2",INT F9"Sanyo",INT FB"Sanyo"
  4701. --------T-FA---------------------------------
  4702. INT FA - DoubleDOS - TURN OFF TIMESHARING
  4703. SeeAlso: INT 21/AH=EAh"DoubleDOS",INT FB"DoubleDOS"
  4704. ----------FA---------------------------------
  4705. INT FA P - ASM Edit - INSTALLATION CHECK
  4706. Program: ASM Edit is a shareware programmer's editor
  4707. Note:    ASM Edit hooks this vector in protected mode to allow DPMI programs
  4708.       to detect whether they were run while shelled to DOS from ASM Edit
  4709.  
  4710. Format of ASM Edit signature block:
  4711. Offset    Size    Description    (Table 3293)
  4712.  00h    BYTE    CFh (IRET)
  4713.  01h  8 BYTEs    signature "ASM Edit" (no trailing NUL)
  4714. --------*-FB---------------------------------
  4715. INT FB - reserved for user interrupt
  4716. --------h-FB---------------------------------
  4717. INT FB - Sanyo MBC-550 - IRQ3 - KEYBOARD USART RECEIVE INTERRUPT
  4718. SeeAlso: INT 0B"IRQ3",INT FA"Sanyo",INT FC"Sanyo"
  4719. --------T-FB---------------------------------
  4720. INT FB - DoubleDOS - TURN ON TIMESHARING
  4721. SeeAlso: INT 21/AH=EBh"DoubleDOS",INT FA"DoubleDOS"
  4722. --------*-FC---------------------------------
  4723. INT FC - reserved for user interrupt
  4724. --------T-FC---------------------------------
  4725. INT FC - DoubleDOS - GET CURRENT SCREEN BUFFER ADDRESS
  4726. Return: ES = segment of display buffer
  4727. Desc:    determine the address of the virtual screen to which the program
  4728.       should write instead of the actual video memory, so that the
  4729.       multitasked programs do not interfere with each other's output
  4730. Note:    the display buffer may be moved if multitasking is enabled
  4731. SeeAlso: INT 21/AH=ECh"DoubleDOS",INT FB"DoubleDOS"
  4732. --------h-FC---------------------------------
  4733. INT FC - Sanyo MBC-550 - IRQ4 - PRINTER READY INTERRUPT
  4734. Note:    normally masked off at the 8259 interrupt controller
  4735. SeeAlso: INT 0C"IRQ4",INT FB"Sanyo",INT FD"Sanyo"
  4736. --------*-FD---------------------------------
  4737. INT FD - reserved for user interrupt
  4738. --------T-FD---------------------------------
  4739. INT FD - DoubleDOS - ???
  4740. --------h-FD---------------------------------
  4741. INT FD - Sanyo MBC-550 - IRQ5 - FLOPPY DISK CONTROLLER
  4742. SeeAlso: INT 0D"IRQ5",INT FC"Sanyo",INT FE"Sanyo"
  4743. --------S-FD---------------------------------
  4744. INT FD - TFPCX - INSTALLATION CHECK
  4745.     AH = function (also see separate entries below)
  4746. Program: TFPCX is an interface between modem and terminal program for packet-
  4747.       radio communications
  4748. Notes:    the installation check consists of testing for the string "N5NX" three
  4749.       bytes beyond the interrupt handler; INT FD is the default, but may
  4750.       be changed, so the full installation check consists of scanning
  4751.       for the signature
  4752.     TFPCX returns AX=FFFFh on any unsupported function call
  4753. SeeAlso: AH=01h,AH=03h,AH=FEh
  4754. --------S-FD01-------------------------------
  4755. INT FD - TFPCX - TEST FOR CHARACTER WAITING
  4756.     AH = 01h
  4757. Return: AX = status
  4758.         0000h no characters waiting
  4759.         0001h character available for input
  4760. Program: TFPCX is an interface between modem and terminal program for packet-
  4761.       radio communications
  4762. SeeAlso: AH=02h
  4763. --------S-FD02-------------------------------
  4764. INT FD - TFPCX - GET CHARACTER
  4765.     AH = 02h
  4766. Return: AL = character
  4767. Notes:    this call is only allowed if AH=01h indicated that a character is
  4768.       available
  4769.     all available characters should be read before sending any additional
  4770.       characters
  4771. SeeAlso: AH=01h,AH=03h
  4772. --------S-FD03-------------------------------
  4773. INT FD - TFPCX - OUTPUT CHARACTER
  4774.     AH = 03h
  4775.     AL = character to send
  4776. Return: nothing
  4777. SeeAlso: AH=02h
  4778. --------S-FDFE-------------------------------
  4779. INT FD - TFPCX - GET VERSION
  4780.     AH = FEh
  4781. Return: AH = major version
  4782.     AL = minor version
  4783. Program: TFPCX is an interface between modem and terminal program for packet-
  4784.       radio communications
  4785. SeeAlso: AH=01h,AH=03h
  4786. --------B-FE---------------------------------
  4787. INT FE - AT/XT286/PS50+ - destroyed by return from protected mode
  4788. Note:    the ROM BIOS uses 0030h:0100h as the initial stack on startup, which
  4789.       is the last fourth of the interrupt vector table.  If the processor
  4790.       is returned to real mode via a hardware reset (the only possibility
  4791.       on an 80286, though there are a number of ways of generating one),
  4792.       then the BIOS startup code stacks three words on its scratch stack
  4793.       before determining that a return to real mode has been requested.
  4794.       As a result, INT FE and INT FF are corrupted.
  4795. SeeAlso: INT FF"XT286"
  4796. --------T-FE---------------------------------
  4797. INT FE - DoubleDOS - GIVE UP TIME
  4798.     AL = number of 55ms time slices to give away
  4799. Return: after other program (if active) has run
  4800. SeeAlso: INT 21/AH=EEh"DoubleDOS",INT F4"DoubleDOS"
  4801. --------G-FE---------------------------------
  4802. INT FE - Turbo Debugger 8086 v2.5+ - OVERLAY MANAGER
  4803. SeeAlso: INT 3F
  4804. --------h-FE---------------------------------
  4805. INT FE - Sanyo MBC-550 - IRQ6 - 8087 COPROCESSOR INTERRUPT
  4806. Note:    normally masked off at the 8259 interrupt controller
  4807. SeeAlso: INT 0E"IRQ6",INT FD"Sanyo",INT FF"Sanyo"
  4808. --------B-FF---------------------------------
  4809. INT FF - AT/XT286/PS50+ - destroyed by return from protected mode
  4810. Note:    (see INT FE"XT286")
  4811. SeeAlso: INT FE"XT286"
  4812. --------b-FF---------------------------------
  4813. INT FF - Z100 - WARM BOOT
  4814. SeeAlso: INT 40"Z100"
  4815. --------h-FF---------------------------------
  4816. INT FF - Sanyo MBC-550 - IRQ7 - USER INTERRUPT FOR EXTERNAL INTERRUPT
  4817. Note:    normally masked off at the 8259 interrupt controller
  4818. SeeAlso: INT 0F"IRQ7",INT FE"Sanyo"
  4819. --------Q-FF---------------------------------
  4820. INT FF U - QEMM-386.SYS v6.0+ - internal
  4821. Notes:    requires that a byte in the conventional-memory stub be set to the
  4822.       desired function number (00h through 0Ch)
  4823. SeeAlso: #3294
  4824.  
  4825. (Table 3294)
  4826. Values for QEMM internal functions:
  4827.  00h    reflect back to Virtual86-mode interrupt handler (default)
  4828.  01h    ???
  4829.  02h    access DR7???
  4830.  03h    QPI upcall (see INT 67/AH=3Fh)
  4831.  04h    ???
  4832.  05h    ???
  4833.  06h    INT 15/AH=87h
  4834.  07h    EMS services (see INT 67/AH=40h,INT 67/AH=5Dh)
  4835.  08h    ???
  4836.  09h    QEMM exception handler
  4837.  0Ah    XMS services (see INT 2F/AX=4310h)
  4838.  0Bh    Virtual DMA Services (see INT 4B/AX=8102h)
  4839.  0Ch    ???
  4840. --------v-FF---------------------------------
  4841. INT FF - VIRUS - "Violetta" - ???
  4842. Note:    used but not chained by virus
  4843. SeeAlso: INT E0"VIRUS",INT F1"VIRUS"
  4844. --------V-FF----BX0000-----------------------
  4845. INT FF - PC/FORTH - GRAPHICS API - VIDEO STATUS CHANGE
  4846.     BX = 0000h
  4847.     DS:SI -> FORTH program counter
  4848.     SS:BP -> FORTH parameter stack
  4849.     SS:SP -> FORTH return stack
  4850.     DS:DX -> FORTH video parameter area
  4851. Desc:    called to inform graphics driver of any status changes such as video
  4852.       mode changes, character color changes, graphics XOR mode turned on
  4853.       or off, etc.
  4854. --------V-FF---------------------------------
  4855. INT FF - PC/FORTH - GRAPHICS API
  4856.     BX = function number
  4857.         0001h function REDRAW
  4858.         0002h function !PEL
  4859.         0003h function @PEL
  4860.         0004h function LINE
  4861.         0005h function ARC
  4862.         0006h function @BLOCK
  4863.         0007h function !BLOCK
  4864.         0008h function FLOOD
  4865.     DS:SI -> FORTH program counter
  4866.     SS:BP -> FORTH parameter stack
  4867.     SS:SP -> FORTH return stack
  4868.     details of parameters not available
  4869. --------!---Admin----------------------------
  4870. Highest Table Number = 3294
  4871. --------!---FILELIST-------------------------
  4872. Please redistribute all of the files comprising the interrupt list (listed at
  4873. the beginning of the list and in INTERRUP.1ST) unmodified as a group, in a
  4874. quartet of archives named INTER52A through INTER52D (preferably the original
  4875. authenticated PKZIP archives), the utility programs in a fifth archive
  4876. called INTER52E.ZIP, the WinHelp-related programs in a sixth archive
  4877. named INTER52F.ZIP, and the non-WinHelp hypertext programs in a seventh archive
  4878. names INTER52G.ZIP.
  4879.  
  4880. Copyright (c) 1989,1990,1991,1992,1993,1994,1995,1996 Ralf Brown
  4881. --------!---CONTACT_INFO---------------------
  4882. Internet: ralf@pobox.com (currently forwards to ralf@telerama.lm.com)
  4883. UUCP: {uunet,harvard}!pobox.com!ralf
  4884. FIDO: Ralf Brown 1:129/26.1
  4885.     or post a message to me in the DR_DEBUG echo (I probably won't see it
  4886.     unless you address it to me)
  4887. CIS:  >INTERNET:ralf@pobox.com
  4888.